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21052 Features: 


@ Implements revision 2.0 PCl-compliant 
drivers 


@® Supports two 32-bit PCI buses 


® Provides maximum clock frequency of 
33 MHz 


@ Provides concurrent primary and secondary 
bus operation 


@ Forwards memory read and write 
transactions in either direction 


@® Forwards I/O read and write transactions 
in either direction 


@ Forwards configuration read and write 
transactions in downstream direction 


® Converts configuration write transactions 
to special cycles in either direction 
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Supports memory transaction filtering 
through two programmable memory 
address regions — one prefetchable 
and one non-prefetchable 


Provides I/O transaction filtering 
through one programmable 
1/O address region 


Provides five secondary PCI clock 
outputs 


Provides programmable rotating arbitration 
function which supports up to four secondary 
bus masters 


The DECchip 21052 PClI-to-PCI Bridge is a low-cost, high-performance chip that expands the 
electrical capacity of all PC! systems (for example, Alpha, Pentium, x86, PowerPC). The 21052 
allows motherboard designers to add more PCI devices or more PCI option card slots than a single 
PCI bus can support. Option card designers can use the 21052 to implement multiple device PCl 


option cards. 


Technical Support 
and Information 


North America: 1-800-332-2717 
TTY: 1-800-332-2515 
Outside 


North America: +1-508-568-6868 





Chip Ordering Information 


1-800-344-4825 
(1-800-DIGITAL) 


North America: 


Outside Contact your local 
North America: Digital sales office 
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Preface 


Purpose and Audience 


This data sheet describes the DECchip 21052 PCI-to-PCI bridge chip (21052). 
The 21052 expands the electrical capacity of all PCI systems such as Alpha, 
Pentium, x86, and PowerPC. The 21052 allows motherboard designers to 
add more PCI devices or more PCI option card slots than a single PCI bus 
can support. Option card designers can use the 21052 to implement multiple 
device PCI option cards. 


This document is for designers who want to expand the electrical capacity of 
their PCI bus architectures. 


Manual Organization 


This manual consists of seven chapters and an appendix. 


Chapter 1 is an overview of the 21052. 
Chapter 2 lists the 21052 pin assignment in alphabetic and numeric order. 
Chapter 3 provides a description of pin signals. 


Chapter 4 describes chip functions, including bus interfaces, transaction 
types, transaction termination, address decoding, arbitration, and other 
functions. 


Chapter 5 provides programmer reference information about configuration 
space registers. 


xiii 


¢ Chapter 6 provides diagnostics information. 


e Chapter 7 lists the electrical characteristics of the chip. 


e Appendix A contains information about DECchip technical support, 
ordering, and associated literature. 


Conventions 


The following conventions are used in this document. 


XIV 


Convention 
Note 
Caution 
Warning 


xtrdy_l 


ytrdy_l 


Meaning 


Provides general information. 
Provides information to prevent damage to equipment. 
Provides information to prevent personal injury. 


PCI signals on the initiator (master) bus are denoted by x 
preceding the PCI signal name. 


PCI signals on the target (slave) bus are denoted by y 
preceding the PCI signal name. 


1 


Introduction 


The DECchip 21052 PCI-to-PCI Bridge (also called the 21052) is a low-cost, 
high-performance chip that expands the electrical capacity of all PCI systems 
such as Alpha, Pentium, x86, and PowerPC. The 21052 allows motherboard 
designers to add more PCI devices or more PCI option card slots than a single 
PCI bus can support. Option card designers can use the 21052 to implement 
multiple device PCI option cards. 


1.1 General Description 


The DECchip 21052 has two PCI interfaces. The primary PCI interface 
connects directly to the PCI bus closest to the host CPU. The secondary PCI 
interface creates a new and independent PCI bus. The primary function of the 
bridge is to allow transactions to occur between a master on one PCI bus and a 
target on the other PCI bus. 


The 21052 also allows the two PCI buses to operate independently. A master 
and a target located on the same PCI bus can communicate with each other 
even if the other PCI bus is busy. As a result, the 21052 can isolate traffic 
between devices on one PCI bus from devices on other PCI buses. This is a 
major benefit to system performance in some applications such as multimedia. 


The 21052 can extend a system beyond the electrical loading limits of a 
single PCI bus. Each new PCI bus created by the addition of a 21052 
provides support for additional electrical loads. Motherboard designers can 
use the 21052 to add more PCI devices or PCI option card connectors to the 
motherboard. Figure 1—1 shows the 21052 on the system board. 
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Figure 1-1 DECchip 21052 PCI-to-PCI Bridge on the System Board 
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Option card designers can use a 21052 to implement multiple device PCI 
option cards. Without a 21052, you can attach only one PCI device to the PCI 
option connector (the PCI Local Bus Specification restricts PCI option cards 
to a single connection per PCI signal in the option card connector). In this 
application, the 21052 creates an independent PCI bus on the option card to 
which many devices can be attached. 


Figure 1—2 shows the 21052 with option cards. 


Figure 1-2 DECchip 21052 PCl-to-PCI Bridge with Option Cards 
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1.2 Features 
The 21052 has the following features: 


Implements revision 2.0 PCI-compliant drivers 

Operates in a 5-volt or 3.3-volt signaling environment 

Supports two 32-bit PCI buses 

Provides maximum clock frequency of 33 megahertz 

Provides concurrent primary and secondary bus operation 

Conditionally forwards the following transactions: 

— Memory read and write transactions in either direction 

— J/O read and write transactions in either direction 

— Configuration read and write transactions in the downstream direction 
— Configuration write transactions to special cycles in either direction 


Supports memory transaction filtering through two programmable memory 
address regions—one prefetchable and one non-prefetchable 


Supports read prefetching for memory read transactions 


Provides up to eight dwords (32 bytes) of write posting for memory write 
transactions 


Provides I/O transaction filtering through one programmable memory I/O 
address region 


| Provides ISA-mode for I/O transaction filtering 


Provides two programmable video graphics adapter (VGA) bits that support 
forwarding of VGA memory and I/O addresses, or forwarding of VGA 
palette I/O writes 


Provides master latency timers and target wait timers for each PCI 
interface, which limit the amount of latency on either bus 


Provides concurrent resource lock operation 
Propagates locks across the 21052 


Provides five secondary PCI bus clock outputs 
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e Enables the following central functions through s_cfn_l input pin for 
secondary bus: 


— Programmable rotating arbitration function supporting up to four 
secondary bus masters 


— Secondary PCI bus parking at the 21052 


e Supports perr and serr signals with error checking functionality 


1.3 Architecture Overview 


The 21052 is implemented in a 3.3-volt CMOS process. It is packaged in a 
160-pin plastic quad flat-pack. 


Figure 1-38 shows the major functions of the 21052, and Table 1—1 describes 
the major sub-blocks. 
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Figure 1-3 DECchip 21052 PCl-to-PCI Bridge Block Diagram 
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Table 1-1 Major Sub-Blocks of the DECchip 21052 


Block 
PSM 


SPM 


SPD 


PSD 


REG 


Description 


Machine and control logic for all transactions initiated on the primary 
interface, whether the transaction is intended for the 21052 itself or a 
target on the secondary side of the 21052. 


Machine and control logic for all transactions initiated on the secondary 
interface. All such transactions are intended for a target on the primary 
interface, since 21052 registers are not accessible from the secondary 
interface. 


Data path for data received on the secondary interface and driven on the 
primary interface. Used for writes initiated on the secondary PCI bus or 
reads initiated on the primary PCI bus. 


Data path for data received on the primary interface and driven on the 
secondary interface. Used for writes initiated on the primary PCI bus or 
reads initiated on the secondary PCI bus. 


Configuration registers and corresponding control logic. Accessible from 
the primary interface only. 


Logic for secondary bus arbitration. Receives s_req_1<3:0>, as well as 
the PPB secondary bus request, and drives one of the s_gnt_1<3:0> lines 
or the PPB secondary bus grant. 
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DECchip 21052 Pin Assignment 


The 21052 is divided into three main functions: 
e Primary PCI bus interface that interacts with the bus closest to the CPU 


e Secondary PCI bus interface that interacts with the bus that is farther 
from the CPU 


e Power supply and miscellaneous functions 


Figure 2—1 shows the 21052 signals, and the 21052 pin assignments are listed 
in alphabetic and numeric order at the end of this chapter. 
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Figure 2—1 | 
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DECchip 21052 Pinout Diagram 
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2.1 Signal Types 
The following table defines the 21052 signal types referred to in this chapter. 


Signal Type Definition 

I Standard input only. 

O Standard output only. 

ts Tristate bidirectional. 

sts Sustained tristate. Active low signal must be pulled high for one 
cycle when deasserting. 

od Standard open drain. 

P Power or ground. 
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2.2 Alphabetic 21052 Pin Assignment List 
Table 2—1 lists the 21052 pins in alphabetic order. 


Table 2-1 Alphabetic Pin Assignment List 


Pin Pin | | 
Pin Number Type Pin Number Type 
goz_l 63 I p_ad<23> 84 ts 
nand_out | 62 O p_ad<24> 79 ts 
p_ad<0> 188 ts p_ad<25> 78 ts 
- p_ad<I> 7 132 ts p_ad<26> 77 ts 
p_ad<2> 130 ts p_ad<27>. 76 ts 
p_ad<3> 129 © ts p_ad<28> 74 ts 
p_ad<4> 127 ts ; p_ad<29> 73 ts 
p_ad<5> 126 . ts p_ad<30> 72 ts 
p_ad<6> 124 ts p_ad<31> 70 ‘ts 
p_ad<7> 123 ts p_cbe_l<0> 122 ts 
p_ad<8> 118 ts p_cbe_l<1> 107 ts 
p_ad<9> 117 ts p_che_l<2> 95 ts 
p_ad<10> 115 ts p_cbe_1<3> 82 ts 
p_ad<ll1> 114 ts p_clk 66 I 
p_ad<12> 113 ts p_devsel_l 100 sts 
p_ad<13> 111 ts p_frame_1 96 sts 
p_ad<14> 110 ts p_gnt_l 68 I 
p_ad<15> 109 ts p_idsel 83 I 
p_ad<16> 93 ts p_irdy_l 97 sts 
p_ad<17> 92 ts p_lock_l 102 sts 
p_ad<18> 91 ts p_par 106 ts 
p_ad<19> 89 ts p_perr_l 104 sts 
p_ad<20> 88 ts | p_req_l 69 ts 
p_ad<21> 87 ts p_rst_l 64 I 


p_ad<22> 85 ts p_serr_l 105 od 


2-4 Preliminary—June 1995 


Pin 
p_stop_l 
p_trdy_l 
p_vio 

s_ ad<0> 
s_ad<l> 
s_ad<2> 
s_ad<3> 
s_ad<4> 
s_ad<5> 
s_ad<6> 
s_ad<7> 
s_ad<8> 
s_ad<9> 
s_ ad<10> 
s_ad<11> 
s_ad<12> 
s_ad<13> 
s_ad<14> 
s_ad<15> 
s_ad<16> 
s_ad<17> 
s_ad<18> 
s_ad<19> 
s_ad<20> 
s_ad<21> 
s_ad<22> 
s_ad<23> 
s_ad<24> 
s_ad<25> 


Pin 
Number 
101 
99 
67 
134 
136 
137 
138 
140 
141 
142 
144 
146 
148 
149 
150 
152 
153 
155 
156 
14 
16 
17 
18 
20 
21 
22 
24 
26 
28 


Type 
sts 


sts 


ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 


Pin 
s_ad<26> 
s_ad<27> 

s ad<28> 

s ad<29> 
s_ad<30> 
s_ad<31> 
s_che_l<0> 
s_cbhe_l<1> 
s_cbhe_l<2> 
s_che_l<3> 
s_cfn_l 
s_clk 

s clk o<0> 
s_clk_ o<I1> 
s_clk_o<2> 
s_clk_o<3> 
s_clk o<4> 
s_devsel_l 
s frame | 
s gnt_1<0> 
s gnt_l<1> 
s gnt 1<2> 
s gnt_l<3> 
s_irdy_l 
s_lock_l 
S_par 

s_ perr_l 

s req 1<0> 


s req l<1> 


Pin 
Number 
29 
ol 
32 
33 
35 
36 
145 
158 
13 


49 
51 
53 
55 
57 
59 
61 


11 
43 
44 
45 
47 
10 


37 
38 
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Type 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 
ts 


(os © lee © ay © ae ee a 


sts 
sts 
ts 
ts 
ts 
ts 
sts 
sts 
ts 


sts 


Pin 
s_req_1<2> 
s_req_1<3> 
s_rst_l 
s_serr_l 
s_stop_l 
s trdy_1 
S_vio 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 
vdd 

vss 

vss 


vss 
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Pin 
Number 
39 

42 

48 

3 


52 


15 
23 
30 
40 
46 
56 
60 
75 
80 
90 
98 
108 
116 
120 
125 
131 
139 
147 
154 
160 


12 
19 


Type 


Pett ig ye ts Res 


sts 


sts 


i na © © I © A © © © © © © © © °° © A ©” °° °° 


Pin 


VSS 


vss 


vss 


VSS 


vss 


vss 


vss 


vss 


Vss 


vss 


vss 


vss 


vss 


vss 


vss 


vss 


vss 


vss 


vss 


VSS 


vss 


Pin 
Number 
27 
34 
41 
50 
54 
58 
65 
71 
81 
86 
94 
103 
112 
119 
121 
128 
135 
143 
151 
157 
159 


Type 


MO. RO OP ie i Ee So os Me OP 


2.3 Numeric 21052 Pin Assignment List 


Table 2-2 lists the 21052 pins in numeric order. 


Table 2-2 Numeric Pin Assignment List 


Pin 

vss 

S_par 
s_serr_l 
s_perr_l 
s_ lock_I 
s_stop_l 
s_devsel_1 
vdd 
s_trdy_l 
s_irdy_l 
s_ frame_l 
vss 
s_cbhe_l<2> 
s_ad<16> 
vdd 
s_ad<17> 
s_ad<18> 
s_ad<19> 
vss 
s_ad<20> 
s_ad<21> 
s_ad<22> 
vdd 
s_ad<23> 


s_cbhe_l<3> 


Pin 
Number 


oO wanna -& WO NH 


Dm NO NH NY NY NH Be BP BR Bee ee eS 
o FP DO NO FH CO MO WAN DA fF WO NY KF CO 


Type 
P 

ts 

I 

sts 
sts 
sts 


sts 


sts 
sts 


sts 


ts 
ts 


ts 
ts 
ts 


ts 
ts 
ts 


ts 
ts 


Pin 

s_ ad<24> 
vss 
s_ad<25> 
s_ad<26> 
vdd 

s ad<27> 
s ad<28> 
s_ ad<29> 
vss 
s_ad<30> 
s_ad<31> 
s_req_1<0> 
s_req_l<1> 
s req_l<2> 
vdd 

vss 

s_ req _1<3> 
s gnt_1<0> 
s gnt_l<1> 
s gnt_1<2> 
vdd 
s_gnt_1<3> 
s_rst_l 
s_cfn_l 


vss 


Pin 
Number Type 

26 ts 
27 Pp 
28 ts 
29 ts 
30 Pp 
ol ts 
32 ts 
33 ts 
34 Pp 
30 ts 
36 ts 
37 I 

38 I 

39 if 

40 Pp 
41 P 
42 I 

43 ts 
44 ts 
45 ts 
46 P 
47 ts 
48 O 
49 I 

50 P 
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Pin 

s_clk 
S_Vvio 
s_clk_o<0> 
vss 
s_clk_o<1> 
vdd 

s_clk o0<2> 
vss 

s clk o<3> 
vdd 
s_clk_o<4> 
nand_out 
goz_l 
p_rst_l 

vss 

p_clk 
p_vio 
p_gnt_] 
p_req_l 
p_ad<31> 
vss 
p_ad<30> 
p_ad<29> 
p_ad<28> 
vdd 
p_ad<27> 
p_ad<26> 
p_ad<25> 
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Pin 
Number 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
712 
73 
74 
75 
76 
77 
718 


Type 


et oct oct oy Oct ttt ct oct 
& & & VG & & UO F & 


Pin 
p_ad<24> 
vdd 

vss 
p_che_l<3> 
p_idsel 


p_ad<23> | 


p_ad<22> 
vss 
p_ad<21> 
p_ad<20> 
p_ad<19> 
vdd 
p_ad<18> 
p_ad<17> 
p_ad<16> 
vss 
p_cbe_l<2> 
p_frame_l 
p_irdy_l 
vdd 
p_trdy_l 
p_devsel_l 
p_stop_l 
p_lock_l 
vss 
p_perr_l 
p_serr_lI 


p_par 


Pin 
Number 
79 
80 
81 
82 
83 
84 
85 
86 
87 
88 
89 
90 
91 
92 
93 
94 
95 
96 
97 
98 
99 
100 
101 
102 
103 
104 
105 
106 


Type 


Pin Pin 


Pin Number Type Pin Number Type 
p_cbe_l<1> 107 ts s_ad<3> 138 ts 
vdd 108 P vdd 139 P 
p_ad<15> 109 ts s ad<4> 140 ts 
p_ad<14> 110 ts s ad<5> 141 ts 
p_ad<13> 111 ts s_ad<6> 142 ts 
vss 112 P vss 143 Pp 
p_ad<12> 113 ts s_ad<7> 144 ts 
p_ad<11> 114 ts s_che_l<0> 145 ts 
p_ad<10> 115 ts s_ad<8> 146 ts 
vdd | 116 P vdd 147 P 
p_ad<9> 117 ts s_ad<9> 148 ts 
p_ad<8> 118 ts s_ad<10> 149 ts 
vss 119 P s_ad<11> 150 ts 
vdd 120 P vss 151 Pp 
vss 121 P s_ad<12> 152 ts 
p_cbe_1<0> 122 ts s_ad<13> 153 ts 
p_ad<7> 123 ts vdd 154 P 
p_ad<6> 124 ts s_ad<14> 155 ts 
vdd 125 P s_ad<15> 156 ts 
p_ad<5> 126 ts vss 157 P 
p_ad<4> 127 ts s_che_l<1> 158 ts 
vss 128 P vss 159 P 
p_ad<3> 129 ts vdd 160 P 
p_ad<2> 130 ts 

vdd 131 P 

p_ad<l> 132 ts 

p_ad<0> 133 ts 

s_ad<0> 134 ts 

vss 135 Pp 

s_ad<l> 136 ts 

s_ad<2> 137 ts 
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3 


Signal Description 


This chapter contains a detailed description of 21052 signals. Signals are 
divided into four major functions: 


e Primary PCI bus 
e Secondary PCI bus 
e Secondary bus arbiter 


e Clocks, reset, and miscellaneous 


Note 


The _l symbol at the end of a signal name indicates that the active, or 
asserted state occurs when the signal is at a low-voltage level. If the _1 
symbol is not present after the signal name, then the signal is asserted 
at the high voltage level. 


The following table describes the signal types referred to in this chapter. 


Signal Type Description 

I Standard input only. 

O Standard output only. 

ts Tristate bidirectional. 

sts Sustained tristate. Active low signal must be pulled high for one 


cycle when deasserting. 


od Standard open drain. 
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3.1 Primary PCI Bus Signals 
The following table describes the primary PCI bus signals. 


Signal Name 


p_ad<31:0> 


p_che_1<3:0> 


p_frame_l 


p_trdy_l 


p_irdy_l 
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Type 
ts 


ts 


sts 


sts 


sts 


Description 


Primary PCI interface address/data. These signals 
represent a multiplexed PCI address and data bus. 
During an address phase of a transaction, p_ad<31:0> 
contains a physical byte address. During subsequent 
data phases, p_ad<31:0> contains data. A PCI bus 
transaction consists of one or two address phases followed 
by one or more data phases. 


Primary PCI interface command/byte enables. 
These signals are multiplexed bus command and byte 
enables. During an address phase of a transaction, 
p_cbe_l<3:0> contains the bus command that defines 
the type of PCI transaction. During data phases, 
p_cbe_l<3:0> contains byte enables dictating which 
byte lanes carry valid data. p_cbe_l<0> applies to byte 
0; p_cbhe_l<3> applies to byte 3. 


Primary PCI interface cycle frame. p_frame_| is 
driven by the initiator of the transaction to indicate the 
beginning and duration of an access on the primary PCI 
bus. p_frame_l assertion indicates the beginning of 

an access. While p_frame_]l is asserted, data transfers 
continue. The deassertion of p_frame_l indicates the 
final data phase. The 21052 samples p_frame_l as an 
input and also drives p_frame_l when acting as the 
initiator of a transaction on the primary PCI bus. 


Primary PCI interface target ready. This signal 
indicates the target’s ability to complete the current data 
phase of a transaction on the primary PCI bus. The 
21052 drives p_trdy_l when acting as a target on the 
primary PCI bus and samples p_trdy_l when acting as 
an initiator on the primary PCI bus. 


Primary PCI interface initiator ready. This signal 
indicates the initiator’s ability to complete the current 
data phase of a transaction on the primary PCI bus. The 
21052 drives p_irdy_1l when acting as an initiator on the 
primary PCI bus and samples p_irdy_l when acting as a 
target on the primary PCI bus. 


Signal Name 


p_stop_l 


p_lock_l 


p_idsel 


p_devsel_l 


p_par 


Type 


sts 


sts 


sts 


ts 


Description 


Primary PCI interface stop indicator. This signal 
indicates that the current target is requesting the bus 
initiator to stop the current transaction on the primary 
PCI bus. The 21052 drives p_stop_l when acting as a 
target on the primary PCI bus and samples p_stop_l 
when acting as an initiator on the primary PCI bus. 


Primary PCI interface resource lock. Indicates an 
atomic operation that may require multiple transactions 
to complete. Resources in the 21052 cannot be locked, 
but the 21052 does propagate locks across the bridge. 
The 21052 samples p_lock_l when acting as a target on 
the primary PCI bus and drives p_lock_! when acting as 
an initiator on the primary PCI bus on behalf of a master 
on the secondary bus. 


Initialization device select. Used as a chip select 
during configuration read and write commands. If p_ 
idsel is detected asserted and the transaction is a Type 
0 configuration command, then the 21052 responds as a 
target to the transaction by asserting p_devsel_l. 


Primary PCI interface device select. Asserted by 
the 21052 through positive decoding of the address on 
p_ad<31:0> when it is accepting a transaction for an 
internal configuration access or when it is forwarding 

a transaction across the 21052. The 21052 samples 
p_devsel_l when it is acting as an initiator on the 
primary PCI bus, and expects p_devsel_l to be asserted 
within five cycles of p_frame_l assertion. Otherwise, the 
transaction is terminated with an master abort. 


Primary PCI interface parity. Even parity, calculated 
on 36 bits composed of p_ad<31:0> and p_cbhe_1<3:0>. 
The p_par signal is generated for all address and data 
phases and is valid one clock cycle after valid data or 
address is driven on p_ad<31:0>. The p_par signal is 
driven and tristated identically to p_ad, except that it 
is delayed one clock cycle. The p_par signal is driven 
by the 21052 when acting as an initiator during address 
phases and write data phases. The p_par signal is 
driven by the 21052 when acting as a target during read 
data phases. The p_par signal is sampled as an input 
during all address phases, and when acting as a target 
during write data phases. 
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Signal Name 


p_serr_] 


p_perr_l 


p_req_l 


p_gnt_l 


Type 
od 


sts 


ts 


Description 


Primary PCI interface system error. Can be pulsed 
by any device residing on the primary PCI bus that 
detects a system error condition. The 21052 can be 
enabled to assert p_serr_] as a result of address parity 
error detection, special cycle data parity error, s_serr_l 
assertion, master aborts or target aborts during posted 
writes, data parity error during posted writes, and 
undelivered posted write data. 


Primary PCI interface parity error detected. 
Asserted when a data parity error is detected, and 
corresponds to p_par driven one clock cycle earlier. The 
21052 asserts p_perr_l when it detects a write data 
parity error when acting as a target, or a read data 
parity error when acting as an initiator. 


Primary PCI bus request. Asserted by the 21052 
to indicate to the bus arbiter that it wants to use the 
primary PCI bus. 


Primary PCI bus grant. When asserted, indicates to 
the 21052 that access to the primary PCI bus is granted. 
The 21052 can start a transaction as soon as p_gnt_l is 
asserted and the bus is idle. 


3.2 Secondary PCI Bus Signals 
The following table describes the secondary PCI bus signals. 


Signal Name 


gs ad<31:0> 


s che 1<3:0> 
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Type 
ts 


ts 


Description 


Secondary PCI interface address/data. These signals 
represent a multiplexed PCI address and data bus. 
During an address phase of a transaction, s_ad<31:0> 
contains a physical byte address. During subsequent 
data phases, s_ad<31:0> contains data. A PCI-to-PCl 
bridge transaction consists of one or two address phases 
followed by one or more data phases. 


Secondary PCI interface command/byte enables. 
These signals represent multiplexed bus command 

and byte enables. During an address phase of a 
transaction, s_cbe_1<3:0> contains the bus command 
defining the type of PCI transaction. During data phases, 
s_che_1<3:0> contains byte enables dictating which byte 
lanes carry valid data. s_cbe_l<0> applies to is 0; 
s_cbhe_l<3> eppHee to byte 3. 


Signal Name 


s frame | 


s_trdy_l 


s_irdy_l 


s_stop_l 


s_ lock | 


s_ devsel l 


Type 


sts 


sts 


sts 


sts 


sts 


sts 


Description 


Secondary PCI interface cycle frame. Driven by 
the initiator of the transaction to indicate the beginning 
and duration of an access on the secondary PCI bus. 
The assertion of s_frame_I indicates the beginning of 
an access. While s_frame_l is asserted, data transfers 
continue. The deassertion of s_frame_l indicates the 
final data phase. The 21052 samples s_frame_l as an 
input and also drives s_frame_l when acting as the 
initiator of a transaction on the secondary PCI bus. 


Secondary PCI interface target ready. This signal 
indicates the target agent’s ability to complete the 
current data phase of a transaction on the secondary 
PCI bus. The 21052 drives s_trdy_l when acting as a 
target on the secondary PCI bus and samples s_trdy_l 
when acting as an initiator on the secondary PCI bus. 


Secondary PCI interface initiator ready. This signal 
indicates the initiator’s ability to complete the current 
data phase of a transaction on the secondary PCI bus. 
The 21052 drives s_irdy_1 when acting as an initiator on 
the secondary PCI bus and samples s_irdy_] when acting 
as a target on the secondary PCI bus. 


Secondary PCI interface stop indicator. This signal 
indicates that the current target is requesting the bus 
initiator to stop the current transaction on the secondary 
PCI bus. The 21052 drives s_stop_] when acting as a 
target on the secondary PCI bus and samples s_stop_l 
when acting as an initiator on the secondary PCI bus. 


Secondary PCI interface resource lock. Indicates an 
atomic operation that may require multiple transactions 
to complete. The 21052 cannot be locked, but it does 
propagate locks across the bridge. The 21052 samples 
s_lock_l when acting as a target on the secondary PCI 
bus and may drive s_lock_] when acting as an initiator 
on the secondary PCI bus on behalf of a master on the 
primary bus. 


Secondary PCI interface device select. Asserted 
by the 21052 through positive decoding of the address 
on s_ad<31:0> when it is forwarding a transaction 
upstream. The 21052 samples s_devsel_l when it is 
acting as an initiator on the secondary PCI bus, and 
expects s_devsel_l to be asserted within five cycles 
of s frame_1! assertion. Otherwise, the transaction is 
terminated with a master abort. 
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Signal Name 


S par 


s serr | 


s perr | 
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Type 


ts 


sts 


Description 


Secondary PCI interface parity. Even parity 
calculated on 36 bits composed of s_ad<31:0> and 
s_che_1<3:0>. The s_par signal is generated for all 
address and data phases and is valid one clock cycle 
after valid data or address is driven on s_ad. The s_par 
signal is driven and tristated identically to s_ad, except 
that it is delayed clock cycle. The s_par signal is driven 
by the 21052 when acting as an initiator during address 
phases and write data phases. The s_par signal is driven 
by the 21052 when acting as a target during read data 
phases. The s_par signal is sampled as an input during 
all address phases, and when acting as a target during 
write data phases. 


Secondary PCI interface system error. Can be 
pulsed by any device residing on the secondary PCI bus 
that detects a system error condition. The 21052 does not 
assert s_serr_l as an output. The 21052 can be enabled 
to detect assertion of s_serr_l as an input and cause 
p_serr_l to assert as a result. 


Secondary PCI interface parity error detected. 
Asserted when a data parity error is detected, and 
corresponds to s_par driven one clock cycle earlier. The 
21052 asserts s_perr_l when it detects a write data 
parity error when acting as a target, or a read data 
parity error when acting as an initiator. 


3.3 Secondary Bus Arbiter Signals 


The following table describes the secondary bus arbiter signals. 


Signal Name 


s req_1<3:0> 


s gnt_1<3:0> 


s_ cfn |! 


Type 
I 


ts 


Description 


Secondary PCI bus request inputs. The 21052 
accepts up to four secondary bus inputs to its secondary 
bus arbiter. The 21052 input to the arbiter is an 
internal chip signal. An asserted level on one of the 

s req_1<3:0> pins indicates that an initiator wishes to 
use the secondary PCI bus. 


If the internal arbiter is disabled, then the s_req_1<0> 
input is reconfigured to be an external secondary bus 
grant input. In this case, an asserted level on s_req_ 
1<0> indicates that the 21052 can start an access on the 
secondary bus. 


Secondary PCI bus grant outputs. The 21052 
secondary bus arbiter can assert one of the s_gnt_1l<3:0> 
outputs to indicate that an initiator can start an access 
the secondary PCI bus if the bus is idle. Only one 

s_ gnt_l<3:0> signal can be asserted during any given 
clock cycle. The 21052 bus grant is an internal chip 
signal. The arbiter can be configured to be in rotating 
mode, or in a dual alternating/rotating mode. 


If the internal arbiter is disabled, then the s_gnt_1<0> 
output is reconfigured to be the 21052 external secondary 
bus request. The 21052 then asserts this signal whenever 
it wants to use the secondary PCI bus. 


Secondary central function enable. When low, the 
on-chip secondary bus arbiter is enabled. Also, the 
secondary PCI bus will be parked at the 21052 when the 
bus is idle. 


When high, the on-chip secondary bus arbiter is disabled 
and an external arbiter should be used. The s_gnt_1l<0> 
input is reconfigured to be the 21052 external secondary 
bus request, and the s_req_l<0> input is reconfigured to 
be the 21052 external secondary bus grant. The external 
arbiter must also park the secondary bus, and can park 
the bus at the 21052 by asserting s_req_l<0> when the 
secondary bus is idle. 
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3.4 Clock, Reset, and Miscellaneous Signals 


The following table describes the clock, reset, and miscellaneous signals. 


Signal Name 


p_clk 


p_rst_l 


s_ clk 


s clk 0<4:0> 


s rst_l 
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Type 
I 


Description 


Primary PCI bus clock input. Provides timing for all 
transactions on the primary PCI bus. All primary PCI 
bus inputs are sampled on the rising edge of p_clk, and 
all primary PCI bus outputs are driven from the rising 
edge of p_clk. Frequencies supported by the 21052 range 
from 0 to 33 megahertz. | 


Primary PCI bus reset. Forces the 21052 to a known 
state. All register state is cleared and all primary PCI 
bus outputs are tristated. The p_rst_l signal may be 
asynchronous with p_clk. The p_rst_l signal must be 
asserted for at least ten PCI clock cycles in order to reset 
the 21052 properly. 


Secondary PCI bus clock input. Provides timing for 
all transactions on the secondary PCI bus. All secondary 
PCI bus inputs, as well as miscellaneous inputs with 

s_ prefixes, are sampled on the rising edge of s_clk; all 
secondary PCI bus outputs, as well as miscellaneous 
outputs with s_ prefixes, are driven from the rising edge 
of s_clk. Frequencies supported by the bridge range from 
0 to 83 megahertz. 


Secondary PCI bus clock outputs. Clock outputs are 

buffered versions of p_clk and may be used as secondary 
PCI bus clocks. If used, one of these clock outputs must 

be used as a bridge s_clk input. 


Secondary PCI bus reset. Asserted by the 21052 
under any of the following conditions: 


e The p_rst_l signal is asserted. 
e The secondary reset bit is set. 
e The chip reset bit is set. 


When the 21052 asserts s_rst_l, it tristates all secondary 
PCI control signals, and drives zeros on s_ad, s_cbe_l, 
and s_par. The s_rst_l signal remains asserted until p_ 
rst_l is deasserted, or the secondary reset bit is cleared. 
Assertion of s_rst_l does not clear the 21052 register 
state, and the 21052 configuration registers are still 
accessible from the primary interface. 


Signal Name 


goz_l 


nand_out 


p_vio 


S_ vio 


Type 
I 


O 


Description 


Diagnostic tristate control. When asserted, tristates 
all bidirectional and tristateable output pins. 


Nand tree diagnostic output. This pin is dedicated 
to the diagnostic Nand tree. The Nand tree starts at 
s_cfn_l and runs counter-clockwise. All inputs, except 
p_clk and s_clk, are used in the Nand tree. The goz_l 
signal should be asserted when the Nand tree feature is 
used. 


Indicates the signaling environment of the primary PCI 
bus as defined in the PCI Local Bus Specification. This 
pin should be connected to the I/O supply voltage for 
the primary PCI bus. If the signaling environment is 
5-volt, the pin is connected to 5-volt. If 3.3-volt, the pin 
is connected to 3.3-volt. 


Indicates the signaling environment of the secondary PCI 
bus as defined in the PCI Local Bus Specification. This 
pin should be connected to the I/O supply voltage for 

the secondary PCI bus. If the signaling environment is 
5-volt, the pin is connected to 5-volt. If 3.3-volt, the pin 
is connected to 3.3-volt. 
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Functional Description 


This chapter provides a functional description of the 21052 including: 
e Bus interfaces and arbitration 
e Transaction types 


e Latency control, exclusive access, and error handling 


4.1 PCI Bus Interfaces 


The 21052 bridges system traffic between the primary PCI bus or the PCI bus 
closer to the CPU, and the secondary PCI bus or the bus farther from the CPU. 


4.1.1 Primary PCI Bus Interface 


The 21052 can act as either initiator or target on the primary PCI bus. 
Primary PCI bus signal names are prefaced with p_. 


The primary PCI interface consists of the standard set of PCI signals. No 
sideband signals are defined. 


4.1.2 Secondary PCI Bus Interface 


Secondary PCI bus signal names are prefaced with s_. 


In addition to the standard PCI bus signals, the secondary PCI interface 
implements additional arbiter and clock signals. The secondary interface has 
neither an idsel input or a reset input. 


The secondary PCI interface accepts a separate clock signal for driving and 
sampling the secondary data and control signals. The 21052 assumes that the 
secondary clock is a buffered version of the primary clock. For a description of 
the skew specification between p_clk and s_clk, see Section 4.12. 


The 21052 also generates five buffered versions of p_clk, called s_clk_o<4:0>, 
which may be used as secondary interface clocks, one of which may be 
connected to s_elk. 
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The secondary interface has a reset output, s_rst_l, that the 21052 drives 
when it detects p_rst_l asserted or the secondary reset control bit is set, or 
when the chip reset bit is set. 


Configuration accesses forwarded to the secondary bus use the upper s_ad pins 
during the address cycle as outgoing secondary idsel signals. The secondary 
interface does not have an idsel input because 21052 configuration space is 
accessible from the primary interface only. 


4.2 PCli Address Phase 


The PCI address phase is denoted by a falling edge of xframe_l. A typical 
PCI transaction consists of a single address phase that lasts for one PCI clock 
cycle. An exception to this is the dual address transaction, which contains a 
64-bit address driven in two subsequent PCI clock cycles. The falling edge of 
xframe_l indicates the first address phase. 


During a PCI address phase, the xad<31:0> signals carry the address of the 
transaction, while xcbe_l1<3:0> signals carry the transaction code. 


The 21052 supports the following address phase features: 
e Linear increment address mode 
e Address and data stepping 


e Dual address support 


4.2.1 Linear Increment Address Mode 


The 21052 supports only linear increment address mode. If any other address 
mode is detected, the 21052 disconnects the transaction after the first burst. 


4.2.2 Address and Data Stepping 


4—2 


The 21052 supports address and data stepping by other address and data 
sources as a target. 


The 21052 uses address stepping as a master only when generating a Type 0 
configuration address phase on the secondary bus. One address step cycle is 
needed to allow the secondary bus idsel signal to become valid, since it may be 
connected to an s_ad line through resistive coupling. 


When address stepping is used, the secondary bus arbiter may deassert a grant 
before the assertion of s_frame_]l but it never asserts another grant in the 
same PCI cycle as the deassertion when the secondary PCI bus is idle. This 
prevents address contention when address stepping is used on the secondary 
interface. 
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4.2.3 Dual Addressing 


Dual-address transactions provide a mechanism to generate a 64-bit address 
on a 32-bit PCI bus. A dual-address transaction consists of two address 
phases. The first address phase contains the least significant 32 bits of the 
address on xad<31:0> and the dual-address command on xcbe_l<3:0>. The 
second address phase contains the most significant 32 bits of the address on 
xad<31:0> and the transaction type command on xcbe_1l<3:0>. 


The 21052 responds to all dual-address transactions on the secondary bus, 
and forwards them to the primary bus. The 21052 ignores all dual-address 
transactions initiated on the primary bus. 


When forwarding a dual-address transaction upstream, the 21052 may post 
write data or prefetch read data, depending on the transaction type. The 21052 
follows the same guidelines for posting and prefetching as described for the 
specific transaction types. 


4.3 Device Select (devsel) Generation 


In all transactions crossing the 21052 that require a return of xdevsel_l to 
the initiator, the 21052 performs positive decoding of the address information 
and conditionally returns xdevsel_l with medium timing to the initiator of the 
transaction. This ensures that xdevsel_l is returned to the initiating device 
within the minimum allowed number of PCI clock cycles (5) after assertion of 
xframe_l. 


If the 21052 does not receive an asserted value of ydevsel_l from the target 
device within the required number of PCI cycles after the 21052 asserts 
yframe_l, the 21052 performs a master abort on the target bus. The 21052 
may be configured to handle master aborts in two different ways based on the 
Master Abort Mode bit. 


In default mode, the 21052 asserts xtrdy_l on the initiator bus and completes 
the transaction. Write data is not delivered, and read data is driven as 
FFFFFFFFh. The Received Master Abort bit is set in the status register 
corresponding to the target bus. 


If the Master Abort Mode bit is set, then the 21052 is enabled to perform a 
target abort on the initiator bus when a master abort is detected on the target 
bus for read and non-posted write operations. The 21052 asserts p_serr_l if a 
master abort occurs during a posted write, if the primary serr driver enable 
is set and the serr disable for master abort is not set. The Received Master 
Abort bit is set in the status register corresponding to the target bus. For 
reads and non-posted writes, the Signaled Target Abort bit is set in the status 
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register corresponding to the initiator bus. For posted writes, the Signaled 


System Error bit is set in the Primary Status Register. 


4.4 Transaction Forwarding 


The 21052 forwards all types of memory, I/O, and configuration commands, and 


also generates special cycles. 


PCI commands are defined by the xcbe_lI signals during the address phase. 


Table 4—1 lists the xcbe_l commands. 


Table 4—1 xcbe_| Commands 


xcbe_| PCI Command 

0000 Interrupt acknowledge 
0001 Special cycle 

0010  T/O read 

0011 I/O write 

0100 Reserved 
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xcbe | 


1000 
1001 
1010 
1011 
1100 


PCI Command 


Reserved 

Reserved 
Configuration read 
Configuration write 


Memory read multiple 


(continued on next page) 


Table 4—1 (Cont.) xcbe_l Commands 


xcbe_|! Command 
0101 Reserved 

0110 Memory read 
O111 Memory write 


4.4.1 Transaction Support 


xcbe_| 
1101 


1110 
1111 


Command 


Reserved 
Memory read line 


Memory write and 
invalidate 


Table 4-2 shows which transactions are supported by the 21052, and whether 
posting or prefetching is used for a particular transaction under normal 


operating conditions. 


e P-S indicates transactions in which the initiator resides on the primary 
side and the target resides on the secondary side. 


e S$ — P indicates transactions in which the initiator resides on the secondary 
side and the target resides on the primary side. 


Table 4—2 Transaction Forwarding and Filtering 
Ss—P 


Transaction 


Interrupt acknowledge 
Special cycle 
I/O read 


I/O write 


Memory read 


Memory write 


Configuration read 


P—S 


Yes 


Yes 


No 
No 
Yes 


Yes 


Yes 


Yes 


Yes 


Notes 


Limited to one data transfer; no 
prefetching. 


Limited to one data transfer; no 
posting. 


Allows prefetching and multiple 
data transfers if addressing the 
prefetchable memory range; 
otherwise, limited to one data 
transfer; no prefetching. 


Posting and multiple data 
transfers allowed. 


Upstream: Type 1 — Type 1 only. 
Limited to one data transfer; no 
prefetching. 


(continued on next page) 
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Table 4—2 (Cont.) Transaction Forwarding and Filtering 


Transaction P—S S—P Notes 


Configuration write — Yes Yes Upstream: Type 1 — Type 1 
and Type 1 — special cycle only. 
Limited to one data transfer; no 
posting. 


Memory read multiple Yes Yes Allows prefetching and multiple 
data transfers with certain 
restrictions. See Section 4.4.4.4 
and Section 4.4.4.5. 


Memory read line Yes Yes Allows prefetching and multiple 
data transfers with certain 
restrictions. See Section 4.4.4.4 
and Section 4.4.4.5. 


Memory write and Yes Yes Posting and multiple data 
invalidate transfers allowed. 
Configuration write — Yes Yes — 


special cycle 


Dual address No Yes Posting, prefetching, and 
burst limitations dependent on 
transaction type. 


4.4.2 Data Path 


Figure 4—1 shows the data path for forwarding transactions across the 21082. 
In each direction eight data buffers are used for either read or write data, and 
an additional register is used to hold and track addresses. 
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Figure 4—1 DECchip 21052 Data Path 
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4.4.3 Write Transactions 


Write transactions may be posted or non-posted. Posted write transactions 
allow multiple burst data transfers to the 21052 before access to the target 
device is acquired. Non-posted write transactions are limited to a single data 
phase. Data is not transferred from the initiator until it is transferred to the 
target. Posted and non-posted write behavior is described in the following 
sections. 


4.4.3.1 Non-Posted Write Transactions 


When a non-posted write to be forwarded is initiated, the 21052 returns 
xdevsel_l to the initiator and attempts to gain access to the target bus. 
After the initiator presents the write data, as indicated by an asserted value 
of xirdy_l, and the 21052 obtains possession of the target bus, the 21052 
propagates the write data across the 21052 and transfers the data to the 
target. After data is successfully transferred to the target by assertion of 
yirdy_l and ytrdy_l, the 21052 transfers the write data from the initiator by 
asserting xtrdy_l. Up to this point, the initiator is held in wait states through 
a target stall. Note that for this type of write, additional latency is incurred 
since information is propagated in both directions across the 21052. Writes of 
this type are limited to a single data transfer. 
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Figure 4-2 shows a non-posted I/O write transaction where the 21052 returns 
a target disconnect after the first data transfer. 


Figure 4—2 I/O Write Timing 
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4.4.3.2 Use of Non-Posted Write Transactions 
Non-posted write transactions are used for: 


e I/O writes 


e Configuration writes 


e Memory writes when the Posting Disabled bit is set in the Chip Control 


register 
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e Memory writes when the target bus is locked, indicated by ylock_l 
asserted. 


4.4.3.3 Posted Write Transactions 


When a posted write to be forwarded is initiated, the 21052 returns both 
xdevsel_l and xtrdy_l to the initiator to start accepting write data, before the 
21052 acquires access to the target bus. The 21052 attempts to gain access 

to the target bus in the same manner and with the same timing as for the 
non-posted write. 


Figure 4—3 shows a posted write transaction. In this diagram, data is posted 
to both upstream and downstream write buffers simultaneously from both the 
primary and secondary buses. As soon as the secondary bus becomes idle, the 
bridge delivers downstream write data to the secondary bus target. When the 
downstream transaction is complete, upstream write data is delivered to the 
primary bus target. 


For posted write transactions crossing the 21052, the initiator can post up to 
8 dwords of data to the 21052 while access to the target bus is acquired. If 
the 21052 does not receive a target response (an asserted value of xtrdy_l) 
by the time the eighth dword is about to be transferred, the 21052 performs 
a target disconnect on the eighth dword transfer. This is because the 21052 
cannot guarantee that the ninth dword will be transferred within eight PCI 
clock cycles. 


If the target returns xtrdy_l before the write buffer is filled and more than 
eight dwords are to be transferred, the 21052 allows continuous write data 
transfers from the initiator until a write boundary is reached. If the target 
device stalls, causing the write buffer to fill, the 21052 causes a target stall on 
the initiating bus until buffer space is available. 


Write buffering allows posted write transactions to proceed at the maximum 
transfer rate of one data transfer per PCI clock cycle. The 21052 introduces a 
delay of two PCI clock cycles between interfaces, but buffering hides the effects 
this latency would have on throughput. 
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Figure 4-3 Simultaneous Upstream and Downstream Posted Memory Writes 
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4.4.3.4 Use of Posted Write Transactions 
Posted write transactions are used for: 


e Memory write transactions 
e Memory write and invalidate transactions 


For posted write transactions, the Disable Posting bit must not be set in the 
Chip Control register in 21052 configuration space. In addition, the target bus 
must not be locked, that is, ylock_1 must be deasserted. 

4.4.3.5 Write Boundaries 


The 21052 imposes write boundaries on posted write transactions. When the 
21052 detects a write boundary, it returns a target disconnect to the initiator 
and completes delivery of posted write data up to the point of disconnection. 


Posted writes are disconnected at cache line boundaries if both of the following 
conditions occur: 


e Transaction is a memory write and invalidate 
e Cache line size is set to a non-zero value, but is less than sixteen. 


Posted writes are disconnected at a 256-dword boundary if one of the following 
conditions occur: 


e Transaction is a memory write 


e Transaction is a memory write and invalidate, and the cache line size 
register is 0 or greater than or equal to 16. (Converted to memory write.) 


The cache line size is programmable in the Cache Line size register in 21052 
configuration space. 


4.4.3.6 Conversion of Memory Write and Invalidate Transactions 


If the 21052 cannot guarantee transfer of a memory write and invalidate 
transaction up to a cache line boundary, it converts the transaction to a 
memory write transaction on the target bus. The 21052 converts a memory 
write transaction in each of the following situations: 


e Cache line size register is set to 0O—the 21052 does not know the cache line 
size. 


e Cache line size register is set to 16 dwords or greater—the 21052 is unable 
to buffer an entire cache line. | 


e Target has returned a target disconnect and a partial cache line remains in 
write buffers. 
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4.4.3.7 


e Cache line size register is set to a value greater than the burst limit 
counter, and the burst limit counter is non-zero. 


The 21052 assumes that the cache line size is a power of 2. If a value that is 
not a power of 2 is written into the cache line size register, the 21052 assumes 
the next lower power of 2 number as the cache line size (that is, if a 6 is 
written, a cache line size of 4 is used). 


Fast Back-to-Back Write Transactions 


The 21052 is capable of responding to fast back-to-back write transactions. The 
21052 does not use fast timing for xdevsel_l assertion and the 21052 state 
machine logic is able to detect the beginning of the second transaction and 
accurately Jecode the address. However, if the first transaction is a posted 
write and both transactions are directed across the 21052, the 21052 returns a 
target retry in response to the second transaction. This is because the 21052 
cannot accept the second transaction until the first transaction is complete on 
both the primary and secondary interfaces. In the case of a posted write, the 
transaction completes on the initiator bus before it completes on the target bus. 
The 21052 can forward back-to-back non-posted writes. The 21052 can also 
accept fast back-to-back single burst configuration writes to its configuration 
space. 


4.4.4 Read Transactions 


4.4.4.1 


Read transactions may prefetch or not prefetch. Reads that do not use 

prefetching are limited to one data phase and only data requested by the 
initiator is read. Reads that use prefetching can consist of multiple data 
phases and can read additional data than that requested by the initiator. 


For either type of read that crosses the 21052, possession of both the initiator 
and target bus, as well as any intermediate PCI buses between the two, must 
be gained before any data is transferred from the target. Non-prefetchable and 
prefetchable reads are discussed in the following sections. 


Non-Prefetchable Reads 


When a non-prefetchable read to be forwarded is initiated, the 21052 returns 
xdevsel_l to the initiator and attempts to gain access to the target bus. When 
the 21052 initiates the transaction on the target bus, it asserts yframe_l for 
only one cycle, indicating a single data transfer request. The 21052 asserts 
only those byte enables asserted by the initiator so that data not requested is 
not read. The 21052 holds the initiator in wait states with a target stall until 
the target device has returned ydevsel_l and ytrdy_! to the 21052, indicating 
that read data is ready. The 21052 propagates the read data across the 21052, 
asserting xtrdy_l to transfer it to the initiator. If a multiple burst transfer is 
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requested, then the 21052 also asserts xstop_l, indicating that no more data 
will be transferred. 


Figure 4—4 shows a non-prefetchable I/O read that is disconnected after the 
first data transfer. 


Figure 4—4 I/O Read Timing 
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4.4.4.2 The Use of Non-Prefetchable Reads 
The 21052 treats the following transactions as non-prefetchable: 


e I/O read 
e Configuration read 


e Memory read and the read address for a downstream read falls into the 
non-prefetchable memory address range (Section 4.6) 


e Upstream memory read and the prefetch disable bit is set in the Chip 
Control register in 21052 configuration space. 


In addition, the 21052 never prefetches data for any type of read where only a | 
single dword is requested and the initiator is not introducing wait states (that 
is, when xframe_l is asserted for only one cycle). 


4.4.4.3 Prefetchable Reads 
The protocol for target access is similar to that for non-prefetchable reads. 
When a prefetchable read to be forwarded is initiated, the 21052 returns 
xdevsel_l to the initiator and attempts to gain access to the target bus. When 
the 21052 gains access to the target bus and begins the read transaction, it 
asserts all byte enables for all data transfers, regardless of which byte enables 
are asserted by the initiator. The 21052 holds the initiator in wait states by a 
target stall until the target device has returned ydevsel_l and ytrdy_1l to the 
21052, indicating that read data is ready. The 21052 propagates the read data 
across the 21052, asserting xtrdy_l to transfer the data to the initiator. 


In prefetchable read (unlike a non-prefetchable read), the 21052 keeps 
yframe_l! asserted on the target bus until either a read boundary is reached or 
until xframe_l deasserts on the target bus, whichever comes first. 


In the case of xframe_lI deassertion, up to four extra dwords, that were not 
requested by the initiator may be read from the target. These extra dwords 
are discarded. If a read boundary is encountered before the initiator deasserts 
xframe_l, no extra dwords are read. 


Figure 4—5 and Figure 4—6 show prefetchable reads. 


Figure 4—5 shows a read up to a cache line boundary. If the initiator had 
requested more data, it would have been disconnected by the 21052. 


Figure 4—6 shows how extra dwords may be read due to the effects of bridge 
latency when forwarding the xframe_| signal. 
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Figure 4—5 Memory Read with Prefetching up to Cache Line Boundary 


paces a ee a a a Ned ee el ed 


p_ad<31:0> 
p_cbe_l<3:0> 
p_frame_| 
p_irdy_| 
p_trdy_| 


p_devsel_| 


s_clk 
s_ad<31:0> 
s_cbe_|l<3:0> 
s_frame_| 
s_irdy_| 
s_trdy_| 


s devsel_| 











LJ-03295-TI0 


Preliminary—June 1995 4-15 


Figure 4—6 Memory Read Multiple with Extra Prefetching 
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4.4.4.4 The Use of Prefetchable Reads 
The 21052 treats the following transactions as prefetchable: 


e Memory read line 
e Memory read multiple 


e Memory read and address of a downstream read falls into the prefetchable 
address range (Section 4.6) 


e Upstream read and the Prefetch Disable bit is not set in the Chip Control 
register in 21052 configuration space 
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4.4.4.5 Read Boundaries 


The 21052 imposes read boundaries on prefetchable reads. When a read 
boundary is reached, the 21052 deasserts yframe_l to the target at the 
beginning of the last data phase to indicate that only one more dword will 

be read. When the 21052 delivers this last longword to the initiator, the 21052 
asserts xstop_l with xtrdy_l, causing a disconnect to occur on that data phase. 


Prefetchable reads are disconnected on cache line boundaries if the cache line 
size register is set to a value other than 0 and one of the following is true: 


Transaction is a memory read and both of these occur: 


Read address falls into the prefetchable address range for downstream 
reads 


Prefetch Disable bit is not set in the Chip Control register for upstream 
reads 


Transaction is a memory read line 


Transaction is a memory read multiple and both of these occur: 


Read address falls into non-prefetchable address range for downstream 
reads 


Prefetch Disable bit is set in the Chip Control register for upstream 
reads 


Figure 4—5 shows a prefetchable read disconnecting on a cache line boundary. 


Prefetchable reads are disconnected on a 256-dword boundary if: 


Transaction is a memory read and the follow is true: 


Cache line size register has a value of 0 


Read address falls into the prefetchable address range for downstream 
reads 


Prefetch Disable bit is not set in the Chip Control register for upstream 
reads 


Transaction is a memory read line and the cache line size register has a 
value of 0. 
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e Transaction is a memory read multiple and 
— Cache line size register has a value of 0 


— Read address falls into the prefetchable address range for downstream 
reads 3 


— Prefetch Disable bit is not set in the Chip Control register for upstream 
reads 


The 21052 assumes that the cache line size is a power of 2. If a value that is 
not a power of 2 is written into the cache line size register, the 21052 assumes 
the next lower power of 2 number as the cache line size (if a 6 is written, then 
a cache line size of 4 is used). 


4.4.5 Configuration Transactions 


To support hierarchical bridging, two types of configuration accesses are 
defined, Type 0 and Type 1. A Type 0 configuration transaction, designated 
when xad<1:0> is set to 00, indicates that the configuration transaction is 
intended for a device that resides on that PCI bus. A Type 1 configuration 
transaction, designated when xad<1:0> is set to 01, indicates that the 
configuration transaction is to be passed on to another PCI bus. 


Figure 4—7 shows the address formats of Type 0 and Type 1 configuration 
accesses. 
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Figure 4—7 Configuration Address Formats 
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The 21052 can respond as the intended target to Type 0 configuration 
transactions initiated on the primary PCI bus. The 21052 ignores all Type 
0 transactions initiated on the secondary PCI bus. Type 0 transactions are 
never forwarded across the 21052. 


The 21052 forwards and converts Type 1 configuration transactions 
downstream as one of the following: 


e Type 1 (on the primary PCI bus) to Type 0 (on the secondary PCI bus) 
e Type 1 (on the primary PCI bus) to Type 1 (on the secondary PCI bus) 
e Type 1 write (on primary PCI bus) to Special Cycle (on secondary PCI bus) 


The 21052 forwards and converts Type 1 configuration transactions upstream 
as one of the following: 


e Type 1 (on the secondary PCI bus) to Type 1 (on the primary PCI bus) 


e Type 1 write (on the secondary PCI bus) to special cycle (on the primary 
PCI bus) , 


Configuration write transactions cannot be posted. Transactions are 
disconnected after transfer of the first dword. The initiator is held in wait 
states by the 21052 until data is successfully transferred to the target. 
Configuration read transactions do not use prefetching. Transactions are 
disconnected after transfer of the first dword, and no additional dwords are 
read from the target during the transaction. 
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4.4.5.1 Type 0 Configuration Transactions 


The 21052 responds only to Type 0 transactions as the intended target on 
the primary PCI bus. All other Type 0 transactions are ignored. The 21052 
responds as the intended target to a Type 0 transaction on the primary bus 
when, during the address phase the following occurs: 


¢ p_idsel is asserted. 
e p_ad<1:0> is set to 0. 
e Function number on p_ad<10:8> is set to 0. 


If these conditions are not met, the 21052 ignores the transaction. If these 
conditions are satisfied, the 21052 performs an access to its configuration state. 
The register number addresses a particular dword in 21052 configuration 
space. 


Configuration access to the 21052 configuration space is disconnected after one 
dword transfer. Figure 4-8 shows a configuration read and write access to the 
21052. 


Figure 4-8 Type 0 contguration Write Access and Configuration Read 
Access 
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4.4.5.2 Type 1 Configuration Transactions 
To determine whether a Type 1 configuration transaction will be forwarded 
or converted, bus numbers are assigned to each PCI bus in the system. The 
following bus numbers are programmable in the 21052 configuration space: 


e Primary bus number—designates the bus number for the 21052 primary 
bus 


e Secondary bus number—designates the bus number for the 21052 
secondary bus 


'e Subordinate bus number—designates the highest bus number of a PCI bus 
behind the 21052 


The range defined by the secondary bus number (inclusive) and the subordinate 
_bus number (inclusive) specify the range of all buses that are downstream from 
the 21052. 


Before any configuration accesses can be made to the secondary PCI bus 
or to any other hierarchical PCI buses on the secondary side of the 21052, 
the secondary bus number of this 21052 must be initialized in the 21052 
configuration space. 


4.4.5.3 Type 1 to Type 0 Conversion 


The 21052 forwards a Type 1 transaction downstream and converts it to 
a Type 0 transaction when the transaction is intended for a device on the 
secondary PCI bus. A Type 1 transaction is forwarded downstream and 
converted to a Type 0 transaction when the following conditions are met 
during the address phase: 


e p_ad<1:0> is 01, indicating a Type 1 transaction. 
e Value on p_ad<23:16> matches the secondary bus number. 


If these conditions are met, the 21052 asserts p_devsel_l to indicate that 
the cycle has been accepted. The 21052 generates a Type 0 configuration 
transaction on the secondary bus with s_ad<1:0> equal to 0 and one of the 
s_ad<31:16> lines, acting as idsel signals on the secondary bus is asserted. 
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Table 4—3 shows the appropriate address line to be asserted is derived from the 
device number driven on p_ad<15:11>. 


Table 4-3 Device Number to s_ad Signal Mapping 





Device Device 
Number Secondary IdSel Number Secondary IdSel 
p_ad<15:11> s_ad<31:16> p_ad<15:11> s_ad<31:16> 
00000 0000 0000 0000 0001 01000 0000 0001 0000 0000 
00001 0000 0000 0000 0010 01001 0000 0010 0000 0000 
00010 0000 0000 0000 0100 01010 0000 0100 0000 0000 
00011 0000 0000 0000 1000 01011 0000 1000 0000 0000 
00100 0000 0000 0001 0000 01100 0001 0000 0000 0000 
00101 0000 0000 0010 0000 01101 0010 0000 0000 0000 
00110 0000 0000 0100 0000 01110 0100 0000 0000 0000 
00111 0000 0000 1000 0000 01111 1000 0000 0000 0000 
10000 - 0000 0000 0000 0000 
11110 
11111 Generate Spec. Cyc. 
(R.No. = 00h) 
0000 0000 0000 0000 
(R.No. > 01h) 


The 21052 can generate Type 0 configuration cycles for up to 16 devices. 
Configuration transactions with device numbers greater than OFh can still be 
forwarded, but the 21052 will not assert any of the s_ad<31:16> lines acting 
as secondary bus idsel lines. Such a transaction is likely to result in a master 
abort, unless some external assertion of a secondary bus idsel line is performed. 
One cycle of additional address stepping is used when driving a Type 0 address 
in order to allow time for the secondary bus idsel line to the target to become 
valid. 


Note 


The 21052 never performs a Type 1 to Type 0 conversion upstream. 


Figure 4-9 shows Type 1 to Type 0 forwarding of configuration read and write 
transactions. In this example, the secondary bus number is 2 and the device 
number is F hex. 
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Figure 4-9 Type 1 to Type 0 Configuration Write and Read 
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4.4.5.4 Type 1 to Type 1 Forwarding 


When the 21052 receives a Type 1 transaction that is intended for any device 
that is not on the secondary bus, it forwards the transaction as Type 1. Type 1 
to Type 1 transactions may be forwarded upstream or downstream. In this 
case, the address is forwarded exactly as received on the initiating bus; no 
conversion is performed. 


A Type 1 transaction is forwarded downstream as a Type 1 transaction when 
the following conditions are met during the address phase: 


e The value on p_ad<1:0> is equal to O1b. 


e The value on p_ad<23:16> is greater than the secondary bus number, but 
less than or equal to the subordinate bus number. 


If these conditions are met, the 21052 asserts p_devsel_| to indicate that 

the transaction is accepted. The 21052 generates a Type 1 transaction on the 
secondary interface. At least two levels of PCI-to-PCI bridging are crossed 
before xtrdy_l can be returned to the initiator for writes or reads, because the 
target device resides on a bus downstream from the secondary PCI bus. 


A Type 1 transaction is forwarded upstream as a Type 1 transaction when the 
following conditions are met during the address phase: 


e The value on p_ad<1:0> is equal to 01b. 


e The value on p_ad<23:16> is not equal to the primary bus number, and 
is outside of the range defined by the secondary and subordinate bus 
numbers. 


This indicates that the transaction is intended for a device upstream of the 
21052, but not on the 21052 primary bus. Typically, this transaction is used to 
generate a special cycle upstream. 


4.4.5.5 Type 1 to Special Cycle Conversion 


Configuration write transactions can be used to pass special cycle messages 
throughout the PCI bus hierarchy. Type 1 configuration transactions can be 
converted and forwarded as special cycles in either direction. The write data is 
used as the special cycle message. 


The 21052 forwards a Type 1 configuration write from the primary bus and 
converts it to a special cycle on the secondary bus when the following conditions 
are met during the address phase: 


e The device number on p_ad<15:11> is equal to all 1’s. 
e The function number on p_ad<10:8> is equal to all 1’s. 


e The register number on p_ad<7:2> is equal to all 0’s. 


4-24 Preliminary—June 1995 


e p_ad<1:0> is equal to O1b. 
e The value on p_ad<23:16> is equal to the 21052 secondary bus number. 


If these conditions are met, the 21052 generates a special cycle on the 
secondary bus using the same address and data that was used for the primary 
configuration write. 


Figure 4—10 shows the write forwarded as a special cycle downstream. 


Figure 4-10 Type 1 Configuration Write to Special Cycle Downstream 
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The 21052 forwards a Type 1 configuration write from the secondary bus and 
converts it to a special cycle on the primary bus when the following conditions 
are met during the address phase: 


e The device number on s_ad<15:11> is equal to all 1’s. 


e The function number on s_ad<10:8> is equal to all 1’s. 
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e The register number on s_ad<7:2> is equal to all 0’s. 

e s_ad<1:0> is equal to Olb. 

e The value on s_ad<23:16> is equal to the 21052 primary bus number. 

If these conditions are met, the 21052 generates a special cycle on the primary 

bus using the same address and data used for the primary configuration write. 
4.4.6 Special Cycles 


The 21052 ignores all special cycle transactions generated on either the 
primary or secondary PCI buses. 


The 21052 provides a mechanism to generate special cycles on either the 


primary or secondary PCI bus through a configuration write transaction 
(Section 4.4.5.5). 


4.4.7 Interrupt Acknowledge 


The interrupt acknowledge transaction is a read operation to the interrupt 
controller. It is assumed that the interrupt controller resides on the primary 
side of the 21052. Therefore, ali interrupt acknowledge transactions are 
ignored by the 21052. 


4.5 Transaction Termination 


The 21052 supports both initiator-initiated terminations and target-initiated 
terminations as both initiator and target. A transaction is complete when both 
xframe_l and xirdy_l are deasserted. 


4.5.1 Initiator Termination 
There are two types of initiator termination: 
e Normal termination 
e Master abort—no target responds to transaction 


4.5.1.1 DECchip 21052 as Target 


If the 21052 is acting as a target during a transaction, then the only type of 
initiator termination possible is normal termination, in which the initiator 
deasserts xframe_l to indicate that the next data transfer is the last transfer, 
and then deasserts xirdy_l at the completion of the last data transfer. When 
the 21052 detects the deassertion of xframe_lI, the 21052 knows to end the 


transaction and deassert and tristate xtrdy_l, xstop_l and xdevsel_l after the 
next data transfer. 
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4.5.1.2 DECchip 21052 as Initiator 


When acting as the initiator, the 21052 can terminate a transaction normally 
or through a master abort. 


4.5.1.2.1 Normal Termination 


The 21052 uses normal termination whenever a target responds with assertion 
of ydevsel_I. The 21052 terminates the following transactions normally: 


e Non-posted write or non-prefetched read, when a single dword burst has 
been transferred 


e Prefetched read, when a read boundary is reached or when the initiator 
deasserts xframe_l (in the latter case, up to four extra dwords may read 
from the target, which are discarded) 


e Posted write, when the write buffer empties and the initiator completes the 
transaction on the initiator bus 


e Prefetched read or a posted write, when the master latency timer expires 
and the initiator does not have the bus grant 


4.5.1.2.2 Master Abort Termination 


If the 21052 initiates a transaction and no target responds within five PCI 
clock cycles after yframe_l assertion, the 21052 terminates the transaction 
with a master abort, indicating an error condition. During a master abort 
termination, the 21052 deasserts yframe_I, and one PCI cycle later, deasserts 
yirdy_l. If yframe_l is already deasserted (only one dword was requested), 
yirdy_l can be deasserted five PCI clock cycles after yframe_l assertion. 


The 21052 has two modes of responding to the initiator on the initiating PCI 
bus (where the 21052 is a target) when a master abort occurs on the target 
bus (where the 21052 is an initiator). The master abort response mode is set 
through the Master Abort Mode bit in the Bridge Control register. If the bit is 
not set (default mode), the 21052 responds to a master abort as follows: 


e Sets the Received Master Abort bit in the status register corresponding to 
the target bus. 


e For a write, asserts xtrdy until one cycle after xframe_l deassertion on 
the initiating bus, transferring write data from the initiator. Write data is 
discarded. 


e For a read, asserts xtrdy until one cycle after xframe_l deassertion on the 
initiating bus and returns FFFFFFFFh for all requested data dwords. 
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If the Master Abort Mode bit is set, the 21052 responds to a master abort as 
follows: 


e Sets the Received Master Abort bit in the status register corresponding to 
the target bus. 


e For a non-posted write, returns a target abort to the initiator. The Signaled 
Target Abort bit is set in the status register corresponding to the initiator 
bus. 


e For a posted write, asserts p_serr_lif the p_serr_l driver control bit in the 
Command Register is set, and the p_serr_l Disable for Master Abort on 
Posted Write is not set. If p_serr_l is asserted, sets the Signaled System 
Error bit in the primary status register. 


e For a read, returns a target abort to the initiator. The Signaled Target 
Abort bit is set in the status register corresponding to the initiator bus. 


A master abort during a special cycle is not considered abnormal termination, 
so none of the previous scenarios apply for special cycles. No event bits are 
set, and the 21052 performs a normal target termination in response to the 
configuration write on the initiator (master) bus. 
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4.5.2 Target Termination 
The 21052 supports the following types of target termination: 


Target abort ystop_l asserted and ydevsel_l deasserted indicates that 
the target will never be able to respond to the transaction. 


Target retry ystop_l and ydevsel_l asserted and ytrdy_1 deasserted 
indicates that the target is not in state ready to accept data. 
No data is transferred during this transaction. 


Target disconnect A/B ystop_l, ytrdy_l and ydevsel_l asserted indicates that 
this data transfer is to be the last data transfer on the 
transaction. At least one dword is transferred during the 
transaction. 


Target disconnect C ystop_I and ydevsel_l asserted and ytrdy_l deasserted 
after previous data transfers are made indicates that 
the most recent data transfer was the last one of the 
transaction. 


4.5.2.1. Target Termination Initiated by Target 


If the 21052 acts as initiator and detects a target abort, retry, or disconnect 
through assertion of ystop_l, then the 21052 terminates the transaction on the 
target bus as soon as possible by deasserting yframe_] and asserting yirdy_l. 
The 21052 then deasserts yirdy_l one cycle later. 


The 21052 responds in different ways on the initiator bus to target 
terminations on the target bus, depending on the type of transaction. See 
Section 4.5.2.1.1 for a summary of 21052 response to target terminations on 
the target bus. 


If a target abort is detected on the target bus, the 21052 does the following: 


e Sets the Received Target Abort bit in the status register corresponding to 
the target bus. 


e If the transaction is a read or a non-posted write, returns target abort to 
the initiator and sets the Signaled Target Abort bit in the status register 
that corresponds to the initiator bus. 


e Ifthe transaction is a posted write, then the 21052: 


— Ifthe p_serr_l driver enable is set and the serr Disable for Target 
Abort on Posted Write is not set, asserts p_serr_l 


— If p_serr_l is driven, sets the Signaled System Error bit in the Primary 
Status Register. 


— Discards any remaining write data; no attempt at delivery. 
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Figure 4—11 shows a target abort during an I/O write, and Figure 4-12 shows 
a memory read with target abort. 


Figure 4-11 1/O Write with Target Abort 
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Figure 4-12 Downstream Memory Read with Target Abort 
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If a target retry is detected on the target bus, the 21052 does the following: 


e Ifthe transaction is a read or non-posted write, returns a target retry to 
the initiator. No data is transferred to or from the initiator or target. 


e Ifthe transaction is a posted write, allows up to a maximum of eight 
dwords to be transferred from the initiator to 21052 write buffers before 
returning a target disconnect. 


Figure 4—13 shows a target retry during an I/O write, and Figure 4-14 shows a 
memory read with target retry. 
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Figure 4—13 Non-Posted I/O Write with Target Retry 
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Figure 4-14 Memory Read with Target Retry 
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If a target disconnect is detected on the target bus, the 21052 does the 
following: 


e Ifthe transaction is a non-prefetched read or non-posted write, then the 
21052 takes no additional action as the 21052 restricts these transactions 
to a single dword transfer. 


e If the transaction is a prefetched read, the 21052 returns a target 
disconnect to the initiator after all requested data read from the target 
is transferred to the initiator. 


e If the transaction is a posted write, the 21052 allows up to a maximum of 
8 dwords to be transferred from the initiator to 21052 write buffers before 
returning a target disconnect (until the write buffer fills). 
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4.5.2.1.1 Target Termination Summary 


The following table summarizes the 21052 response to target termination 
scenarios for different types of transactions. 


Transaction Type 


Posted write 


Non-posted write 


Prefetched read 


Non-prefetched read 
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Target 
Termination 


Retry 


Disconnect 


Abort 


No response 


Retry 


Disconnect 


Abort 


No response 


Retry 
Disconnect 
Abort 


No response 


Retry 


Chip Action 


Accepts up to 8 dwords until write buffer is 
full. Attempts to deliver write data up to 
274 times; if unsuccessful, asserts p_serr_1. 


Accepts up to 8 dwords until write buffer is 
full. Attempts to deliver write data up to © 
2°“ times; if unsuccessful, asserts p_serr_l. 


Returns target abort to initiator if posting 
not complete. Asserts p_serr_] if the serr_l 
disable for this condition is not set and the 
p_serr_l driver enable is set. 


Maintains assertion of xtrdy_l to initiator; 
data is not delivered. Asserts p_serr_l if 
the serr disable for this condition is not set 
and the p_serr_I driver enable is set. 


Returns target retry to initiator. 


Because the 21052 is limited to one burst, it 
always returns target disconnect to initiator 
after one data transfer. 


Returns target abort to initiator. 


Mode 0: Asserts xtrdy_l to initiator; data is 
not delivered. 
Mode 1: Returns target abort to initiator. 


Returns target retry to initiator. 
Returns target disconnect to initiator. 
Returns target abort to initiator. 


Mode 0: Asserts xtrdy_l to initiator; 
returns FFFFFFFFh. 
Mode 1: Returns target abort to initiator. 


Returns target retry to initiator. 


Target 
Transaction Type Termination Chip Action 


Disconnect Because the 21052 is limited to one burst, it 
always returns target disconnect to initiator 
after one data transfer. 


Abort Returns target abort to initiator. 


No response Mode 0: Asserts xtrdy_l to initiator; 
returns FFFFFFFFh. 
Mode 1: Returns target abort to initiator. 


4.5.2.1.2 Delivery of Posted Write Data after Transaction Termination 


If a target retry or target disconnect is received by the 21052 during a posted 
write, the 21052 allows the initiator to continue posting write data until 

the write buffer is full (a maximum of 8 dwords). After the target retry or 
disconnect is received by the 21052, posted write data may still remain in the 
write buffers that has not been transferred to the target. 


When write data remains in the 21052 write buffers after a transaction to 

the target is terminated, whether by target termination or master latency 
timer expiration, the 21052 reattempts the write transaction to the target in 
order to empty the 21052 write buffer. The 21052 continues to attempt the 
write transaction until the write data is successfully transferred, or until the 
maximum number of attempts 22* (16777216) are completed. The purpose of 
the write counter is to prevent indefinite hangs if the 21052 is unable to deliver 
write data. 


Figure 4-15 shows a target retry during a posted write with subsequent write 
attempts. 
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Figure 4-15 Posted Write with Target Retry 
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If the maximum number of attempts are made and the 21052 has not 
successfully transferred the buffered data, the 21052 asserts the p_serr_l 
line, if the p_serr_l driver enable is set and the serr Disable for Delivery of 
Posted Write Data Failed is not set. The write data is discarded. 


If the transaction is a memory write and invalidate and the write is 
disconnected after partial cache line transfer, remaining attempts at delivery 
of write data will use the memory write command because a partial cache line 
will be transferred. 


4.5.2.2 Target Termination Initiated by 21052 


The 21052 may return target retries or target disconnects to the initiator for 
reasons other than target retry or disconnect from the intended target. 


The 21052 returns a target retry to the initiator in the following situations: 


e The 21052 is forwarding another transaction or there is data in one of the 
21052 write buffers. Refer to Section 4.8 for detailed information. 


e The transaction is a read or non-posted write, the target wait timer is 
expired, and the 21052 does not have the grant for the target bus. 
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e The transaction is a locked transaction, but the target bus lock is already 
being used by another initiator. 


The 21052 returns a target disconnect to the initiator for the following 
transactions: 


e Non-posted write or non-prefetched read, and this is the first data transfer 


e Posted write, and the write buffer fills (8 dwords) before the intended 
target returns ytrdy_l 


e Posted write, and the write buffer fills (8 dwords) after expiration of 
the master latency timer and before the target returns ytrdy_l for a 
subsequent write attempt 


e Posted write, and a write boundary has been reached 
— Cache line boundary for memory write and invalidate 
— 256-dword boundary for memory write 


e Prefetched read, and the transaction on the target bus is terminated due to 
master latency timer expiration 

e Prefetched read, and a read boundary is reached 
Cache line or 256-dword boundary for memory-type reads, depending on 
various conditions 

e Burst count limit is reached 


A target abort is returned to the initiator by the 21052 only when a target 
abort is detected on the target bus during a read or non-posted write, or an 
initiator abort occurs on the target bus and the Master Abort Mode bit is set. 


4.6 Address Decoding 


The 21052 has three programmable address ranges which determine whether 
memory and I/O transactions are forwarded across the 21052 or ignored. There 
are two address ranges for memory transactions, and a single address range 
for I/O transactions. The 21052 also has an ISA Compatibility mode and two 
modes of operation for VGA support. 


There are no address holes when forwarding and filtering memory and I/O 
transactions. If transactions with a given address are forwarded across the 
21052 from one bus, they will be ignored when initiated on the other bus. 
Similarly, if transactions with a given address are ignored on one PCI bus, they 
will be forwarded when initiated on the other bus. 
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4.6.1 Memory Address Decoding 


The 21052 implements two programmable memory ranges for memory 
transaction forwarding: 


e A non-prefetchable address range specified by a Memory Base Address 
register (inclusive) and Memory Limit Address register (inclusive) in 
configuration space. Downstream memory read transactions addressing 
this space do not use prefetching. The space has a minimum size, 
granularity, and alignment of 1 megabyte. 


e <A prefetchable address range specified by a Prefetchable Memory Base 
Address register (inclusive) and Prefetchable Memory Limit Address 
register (inclusive) in configuration space. Downstream memory read 
transactions addressing this space use prefetching. The space has a 
minimum size, granularity, and alignment of 1 megabyte. 


4.6.1.1 Memory Transaction Forwarding Based on Address Ranges 


When the 21052 detects a memory read or memory write operation, it compares 
the address against two address ranges in order to determine whether the 
transaction is forwarded or not. 


If the initiator is on the primary bus, then the address must fall within one of 
these two defined address ranges in order for the transaction to be forwarded 
to the secondary bus. There should be no overlap between the two ranges; if 
overlap exists, the guidelines for the non-prefetchable space are used. 


If a memory operation is initiated on the secondary bus, the 21052 checks to 
see if the address falls outside of both of the address ranges described by the 
prefetchable and non-prefetchable memory base and limit address registers. 
If the address is outside of these ranges, the transaction is forwarded to the 
primary bus and the 21052 acts as an initiator on that bus, and as a target on 
the secondary bus. 


4.6.1.2 Disabling a Memory Address Range 
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Setting the memory limit address register to a value less than its respective 
memory base address register turns that address range off. If both memory 
limit registers are set to a value less than their respective memory base 
address registers, the 21052 will not forward any memory transactions from 
the primary to secondary bus, but will forward all memory transactions 
initiated on the secondary bus to the primary bus. Note that the reset 
condition for the registers defines an address space of 00000000h—O000FFFFFh 
in both prefetchable and non-prefetchable space for forwarding to the secondary 
bus. 
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4.6.1.3 VGA Frame Buffer Support 


The 21052 also performs some memory address decoding and forwarding 

for frame buffer memory. If the frame buffer memory range is enabled 

by the VGA Enable bit in the Bridge Control register configuration space, 
transactions initiated on the primary bus with memory addresses in the range 
000OA0000h—OOOBFFFFh will be forwarded downstream, and transactions 
initiated on the secondary bus whose addresses fall within that range will 

be ignored. Read operations to frame buffer memory will be treated as 
prefetchable. 


4.6.1.4 Dual Transaction Addressing 


Dual address transactions are never forwarded downstream, and are always 
forwarded upstream. No address decoding is performed. 


4.6.2 I/O Address Decoding 


The 21052 implements a single programmable memory range for I/O 
transaction forwarding specified by an I/O Base Address register (inclusive) 
and I/O Limit Address register (inclusive) in configuration space. The space 
has a minimum size, granularity, and alignment of 4 Kbytes and a maximum 
I/O space of 64 Kbytes. 


I/O Transaction Forwarding Based on Address Range 


If an I/O transaction is initiated on the primary bus, and the address falls 
inside the range defined by the I/O Base Address register and I/O Limit 
Address register, the 21052 forwards the transaction to the secondary bus. The 
21052 acts as an initiator on the secondary bus and as a target on the primary 
bus. 


If an I/O read or write transaction is initiated on the secondary bus, the 
21052 forwards the transaction to the primary bus if the address falls outside 
the address range described by the I/O Base Address register and I/O Limit 
Address register. 


Any transactions that address over 64K of I/O space are ignored on the primary 
PCI bus and forwarded upstream from the secondary PCI bus. 


4.6.2.2 Disabling the I/O Address Range 


If the I/O Limit Address register is set to a value less than the I/O Base 
Address register, the 21052 will not forward any I/O transactions from the 
primary to secondary bus, but will forward all I/O transactions initiated on 
the secondary bus to the primary bus. Note that the reset condition for the 
registers defines an address space of 0000h—OFFFh for ss to the 
secondary bus. 
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4.6.2.3 ISA Mode 


The 21052 may be programmed to be ISA-bus aware through the ISA Mode bit 
in the Bridge Control register in configuration space. This feature enables a 
finer granularity filtering mechanism for I/O read and write transactions. ISA 
I/O target cards decode only the lowest 10 bits of the address, which represents 
1K of address space. The upper 768 bytes of this 1 Kbyte address space are 
allocated to general I/O ISA target cards. Because these devices do not decode 
the upper address bits <15:10>, their addresses are aliased and repeated 64 
times, for every 1 Kbyte chunk in the 64 Kbyte address space. Thus, if an ISA 
card is present it would respond to its address in every 1 Kbyte chunk. 


Because of address aliasing, non-ISA devices should not use I/O addresses in 
the upper 768 bytes of each 1 Kbyte chunk if an ISA card is present. Likewise, 
the 21052 should not forward transactions in this address range if an ISA card 
is present, regardless of whether the address falls within the I/O base and limit 
address range. , | 


Only transactions addressing the first 256 bytes of each 1 Kbyte chunk can be 
forwarded. When ISA Mode Enable is set, the 21052 prevents the forwarding 
of I/O transactions that address the top 768 bytes of each 1 Kbyte chunk in 
I/O space. This blocking mechanism affects only those transactions initiated 
on the primary bus. The 21052 will not respond to blocked transactions on 
the initiating (primary) bus. However, as a consequence, addresses of I/O 
transactions initiated on the secondary bus that fall into the upper 768 Kbyte 
range will be forwarded upstream, regardless of where the address falls with 
respect to the I/O base and limit address range. 


If the ISA Mode Enable bit is not set, transactions that address the upper 
768 bytes of each 1 Kbyte chunk of I/O space are forwarded or filtered 
normally according to the I/O Base Address and I/O Limit Address registers. 
Figure 4-16 shows the ISA mode for downstream forwarding when the enable 
is set. In order to correctly use the ISA mode, the I/O Base and Limit 
address register should be set so that there is no overlap with ISA or EISA 
system-specific addresses in the lower 256 bytes of the first 4 Kbytes of I/O 
space. 
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Figure 4-16 Downstream I/O Forwarding in ISA Mode 
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4.6.3 VGA I/O Support 
The 21052 has two modes of VGA support: 


e VGA Mode for forwarding all VGA memory and I/O accesses enabled when 
the VGA Enable bit is set in the Bridge Control register in configuration 
space 


e VGA Snoop Mode for snooping (forwarding) VGA palette I/O writes, 
enabled when the VGA Snoop bit is set in the Bridge Command register in 
configuration space 


4.6.3.1 VGA Mode 


When VGA Mode is enabled, the 21052 forwards downstream all memory 
transactions that address frame buffer memory and all I/O transactions that 
address VGA I/O space (Section 4.6.1.3). 


In VGA Mode, any I/O transactions in the 08BOh—03DFh range, with 

the exception of printer port byte addresses 3BCh—8BFh, are forwarded 
downstream when initiated on the primary bus, and ignored if initiated on 
the secondary bus. When VGA Mode is enabled, bits <31:16> of the I/O 
address must be 0 in order for the 21052 to recognize and forward VGA I/O 
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transactions. Bits <15:10> will not be decoded. VGA I/O addresses are aliased 
in every 1K block of I/O space. These aliased transactions are forwarded. 


This VGA I/O forwarding is independent of the I/O address region and the ISA 
Mode filtering. This means that whenever the VGA bit is set, the transactions 
previously described are forwarded regardless of whether they fall inside the 
I/O Base and Limit Address range, and regardless of whether the ISA Mode bit 
is set. 


If the VGA enable bits are not set, the 21052 uses the Base and Limit 
Address registers for memory and I/O forwarding, and VGA addresses are 
forwarded or filtered depending on whether they fall within the base and limit 
address ranges. If ISA Mode is enabled and VGA Mode is disabled, VGA I/O 
transactions are not forwarded downstream, since the addresses fall within the 
upper 768-byte address range. 


4.6.3.2 VGA Palette Snooping 


When the VGA Snoop Mode bit is set, the 21052 positively decodes and 
forwards downstream VGA palette register writes. VGA palette register 
writes use I/O byte addresses 03C6h, 038C8h, and 08C9h. Bits <31:16> must 
be 0 while bits <15:10> may be any value. If VGA Snoop Mode is enabled, the 
21052 ignores any write transactions initiated on the secondary bus that use 
these three addresses. The 21052 ignores read transactions from the primary 
bus that use these addresses, but forwards upstream those initiated on the 
secondary bus. 


The 21052 does not check byte enables when these I/O addresses are 
forwarded, but forwards byte enables as generated by the initiator. The VGA 
Palette Snoop Mode should not be used with VGA mode. However, if both bits 
are set, VGA Mode behavior is used. 


4.7 Latency 


Under normal data transfer conditions, there will be two PCI clock cycles of 
delay between data driven on one PCI bus and data driven on the opposite 
bus. Increased latency occurs after the address phase of a transaction, with 
the exception of posted writes because the 21052 must gain access to the 
target bus and detect a response from the target before any data transfers may 
proceed. This latency increases for every level of PCI-to-PCI bridging that the 
transaction uses. If the 21052 target wait timer is enabled and expires before 
the 21052 gains access to the target bus, the 21052 performs a target retry to 
the initiator and deasserts its request for the target bus. 
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For multiple burst read or write transactions, data transfers may occur on 
every PCI clock cycle. Data buffering in the 21052 allows it to hide the effects 
of 21052 latency on throughput. With the exception of the first data phase, the 
total length of all stall conditions remains the same on both the initiator and 
target buses. No extra stall cycles are added as a result of 21052 latency. Due 
to 21052 latency and prefetching, up to four extra reads from the target may 
be performed at the end of a prefetched read transaction. 


4.7.1 Master Latency Timer 


The 21052 implements two programmable master latency timers. 


e The primary master latency timer—used when the 21052 acts as an 
initiator on the primary PCI bus. 


e The secondary master latency timer—used when the 21052 acts as an 
initiator on the secondary PCI bus. 


The appropriate master latency timer is started when the 21052 asserts 
yframe_l. If the master latency timer expires and the bus grant is deasserted, 
the initiator must deassert yframe_l at the beginning of the next data phase, 
with the possible exception of memory write and invalidate transactions. If the 
grant is still asserted when the latency timer expires, the initiator may retain 
control of the bus and continue the transaction until the grant deasserts. 


Upon termination of the transaction on the target bus due to master latency 
timer expiration, the 21052: 


e For a read, returns a target disconnect to the initiator when the last dword 
read from the target is driven on the initiating bus. 


e For posted memory write, allows the initiator to continue posting data 
until the write buffer is full, and then returns a target disconnect. Write 
data is delivered to the target with subsequent memory write transactions 
initiated by the 21052. 


e For a memory write and invalidate, performs no extra action because the 
initiator may terminate these transactions only on cache line boundaries. 
The 21052 always terminates a memory write and invalidate on the first 
cache line boundary. 
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4.7.2 Target Wait Timer 


The 21052 implements two programmable target wait timers, one for the 
primary interface and one for the secondary interface. The appropriate timer 
is started when the 21052 asserts xdevsel_l to the initiator. If the 21052 is 
waiting for access to the target bus before the transaction can proceed on the 
initiator bus, the target wait timer is expired, and the 21052 does not have the 
target bus grant, the 21052 deasserts its request for the target bus and returns 
a target retry on the initiator bus. 


If the target wait timer expires and the 21052 has the bus grant but cannot 
yet start the transaction because the target bus is still busy, no action occurs 
and the 21052 may continue with the transaction. However, if the grant is 
subsequently deasserted before the 21052 can start its transaction, the 21052 
must deassert its request and return a target retry to the initiator. 


The maximum value for this timer is 22 PCI cycles, which is approximately 
7.6 microseconds for a 33-megahertz system. This feature is disabled if the 
register contains a value of 0. 


4.7.3 Burst Limit Counter 


The 21052 provides a programmable burst limit counter. This allows the user 
to limit the number of data transfers per transaction. For example, the user 
may wish to use the burst limit counter to limit power dissipation for thermal 
reasons. Data bursts can be limited to 1 to 64 bursts per transaction. A value 
of 0 in this register places no burst limit on transactions. If the burst counter 
expires during a transaction, the 21052 terminates the transaction normally on 
the target bus by deasserting yframe_l, and returns a target disconnect to the 
initiator. 


The burst counter applies to both upstream and downstream transactions. 
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4.8 Deadlock Avoidance 
The following rules apply to transactions that cross the 21052: 


In most cases, the current transaction crossing the 21052 must be complete 
on both interfaces before the next transaction to be forwarded can proceed. 
However, there are some exceptions: 


Posted writes may be transferred to the 21052 on both interfaces 
simultaneously, although data is driven to the target on one interface 
at a time. 


A non-posted write is allowed to cross the 21052 if posted write data 
exists in data buffers in the opposite direction. 


Configuration access to 21052 configuration space will be allowed to 
proceed if an upstream posted write is in progress or if there is data in 
upstream write buffers. 


If transactions initiated close to the same time on both the primary and 
secondary buses are intended for targets on the opposite interface and the 
exceptions listed in the previous bullet do not apply, 


The transaction initiated first is forwarded across the 21052, and the 
21052 performs a target retry in response to the second transaction. 


If both transactions are initiated during the same PCI cycle, the 
transaction initiated on the primary bus is forwarded across the 21052, 
and the 21052 performs a target retry in response to the secondary bus 
transaction. 


4.8.1 Read Operations 


For all read operations, if a read is already initiated on one PCI bus intended 
for a target on the opposite PCI bus, and a second transaction, also intended 
to cross the 21052, is initiated on the opposite bus before the read occurs, the 
21052 issues a retry to the initiator of the second transaction. 


4.8.2 Posted Write Operations 


For posted write transactions, in order to prevent potential deadlock conditions 
in a hierarchical PCI bus environment, the 21052 allows memory write data to 
be posted simultaneously in both directions. 


If the target bus is not idle by the time the write buffer fills, the write 
transaction is disconnected. This applies to both the upstream and the 
downstream transactions. 


| 
Preliminary—June 1995 4—45 | 


4.8.3 Non-Posted Write Operations 


For all non-posted write operations, if a non-posted write is already initiated 
on one PCI bus intended for a target on the opposite PCI bus, and a second 
transaction, also intended to cross the 21052, is initiated on the opposite bus 
before the non-posted write occurs, the 21052 issues a retry to the initiator of 
the second transaction. 


4.9 Exclusive Access 


The 21052 supports the resource lock mechanism to achieve exclusive access to 
a target for transactions that cross the 21052. Primary and secondary bus lock 
mechanisms are assumed to be concurrent, except when a locked transaction 
crosses the 21052. 


4.9.1 Acquiring Exclusive Access 


If the initiator wants to create a lock on a target on the other side of the 21052, 
the initiator must first gain access to the xlock_l signal on its bus. A lock is 
gained on the initiating bus when the initiator: 


e Acquires access to the initiator bus while xlock_1 is deasserted 
e Deasserts xlock_] during the address phase of the transaction 
e Asserts xlock_1 one cycle later 


After the initiator gains the lock on its bus, the 21052 attempts to gain access 
to ylock_l on the target bus. The 21052 must: 


e Acquire access to the target bus while ylock_l is deasserted 
¢ Deassert ylock_I during the address phase of the transaction 
e Assert ylock_] one cycle later 


Note that, in accordance with the PCI Specification, the first transaction of a 
locked sequence must be a read. Figure 4-17 shows a downstream read with 
lock acquisition. 
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Figure 4-17 Memory Read with Lock Acquisition 
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For a locked transaction involving a dual address transaction, the xlock_l 
signal should deassert during the first address phase, and reassert at the start 
of the second address phase. 
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If a target retry, target abort, or master abort occurs in response to the first 
transaction in a locked sequence before any data is transferred, the initiator 
must relinquish the lock by deasserting xlock_l. This implies that, if the 
intended target returns a target retry or target abort, causing the 21052 to 
relinquish the lock on the target bus, this target termination must be passed 
back to the initiator in order to force the initiator to relinquish the lock on the 
initiator bus. Because the first transaction of a locked series of transactions is 
a read, the 21052 normally performs this action. 


In some situations, the 21052 causes a target retry to occur in response to a 
lock acquisition transaction by the initiator, causing the initiator to relinquish 
the bus: 


e The 21052 chip is already forwarding another transaction. 


e The ylock_1 signal on the target bus is asserted, indicating that another 
initiator has control of the lock on the target bus (Figure 4—18). 


e The target wait timer expires before access to the target bus is gained. 


Figure 4-18 shows a target retry due to the target bus lock being busy. 
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Figure 4-18 Read with Lock Acquisition Attempt 
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If the 21052 detects a master abort on the target bus, this condition is returned 
to the initiator bus as either normal termination or a target abort. If a target 
abort is returned, the initiator relinquishes the lock. If normal termination 
occurs, then the initiator should recognize that the FFFFFFFFh read data 
condition indicates a master abort; otherwise the initiator might retain 
possession of the lock until the locked sequence ends. 
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4.9.2 Maintaining Exclusive Access 


4-50 


After a lock is achieved on both buses, it must be maintained on both buses 
until the initiator relinquishes the lock or until a master abort or target abort 
is detected on any locked transaction. A transaction is considered a locked 
transaction when the initiator deasserts xlock_l at the start of the address 
cycle, then asserts xlock_l one phase later. 


Figure 4—19 shows a downstream memory write with lock continuation. 


The 21052 always relinquishes the lock on the target bus upon detection 

of the master abort condition. After a lock is established, if a master abort 
occurs on a subsequent locked write, then the 21052 relinquishes the lock on 
the target bus and the target becomes unlocked. However, if the 21052 is in 
default master abort mode, then the initiator can keep xlock_I asserted on the 
initiator bus because the initiator does not know the transaction on the target 
bus resulted in a master abort. The only effect this should have is to tie up 
the xlock_1 signal longer than necessary. If the 21052 is configured to return 
target abort when a master abort is detected, both initiator and 21052 will 
relinquish the initiator and target bus locks. 
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Figure 4-19 Downstream Memory Write with Lock Continuation 
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Target aborts are passed back to the initiator for all transactions, as posted 
writes are not allowed when the target bus is locked. To prevent deadlocks 


when locks are in use, all writes are are not postable as long as ylock_l on the 


target bus is asserted. This allows the 21052 


e To pass back any target aborts, so the lock can be relinquished on the 
initiator bus. 


e To detect master aborts on the secondary bus and cause the initiator to 


relinquish the lock. The 21052 can be configured to return a target abort 
on the initiator bus when a master abort is detected. When in this mode, a 
master abort that is returned to the initiator as a target abort, will cause 


the initiator to relinquish the lock. 


e To pass back any target retries to the initiator of the transaction, and 
allows the initiator that has locked the target to forward transactions 


across the 21052 to the locked target. This prevents deadlock if a different 
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initiator attempts to access a locked target across the 21052 when posted 
write and write data are stranded in write buffers. 


4.9.3 Ending Exclusive Access 


Exclusive access is terminated when the xlock_l is deasserted at the end of a 
transaction. Deassertion of xlock_I must occur no earlier than the first cycle 
where xframe_l and xirdy_l are deasserted, ending the transaction. The 
xlock_l signal can be deasserted after this point, and should be deasserted as 
soon as possible. 


When exclusive access is terminated on the last data phase of a transfer, the 
21052 may not be able to release the lock on the target bus until two cycles 
after the deassertion of xlock_I on the initiator bus. This delay is due to the 
2-clock-cycle latency of the 21052. Therefore, the ylock_I might stay asserted 
for a few cycles after completion on the last data phase on the target bus. 


Figure 4—20 shows a memory write which ends a series of locked transactions. 
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Figure 4-20 Memory Write with End of Lock 


p_ad<31:0> >--(Adar (Data 7} ---- 
pecbelesio> =--(_7 {OS : 
p_frame_| ee 


p_irdy_| 





p_lock_| 
p_trdy_| 


p_devsel_| 


s_clk 
s_ad<31:0> 
s_cbe_l<3:0> 
s_frame_l 


s_irdy_| 





s_lock_| 


s_trdy_| 





s_devsel_| 


LJ-03300-TIO 


DECchip 21052 as a Locked Target 
The 21052 does not support lock as an intended target. 


4.10 Error Handling 


The 21052 implements the data parity error signals p_perr_l and s_perr_l 
on both interfaces, and also implements the address parity and system error 
signals p_serr_l and s_serr_l on both interfaces. This section describes parity 
checking and generation, as well as the different conditions under which 
p_serr_l is asserted. 
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4.10.1 Address Parity Errors 
If the 21052 detects an address parity error on either interface, then the 21052: 


Does not respond as a target to the transaction. 


Sets the Detected Parity Error bit in the Status register that corresponds 
to the interface where the parity error was detected. 


Asserts p_serr_l and set the Signaled System Error bit in the Primary 
Status register if: 


— The p_serr_I Driver Enable is set. 


— The Parity Error Response bit is set in the Command register (if 
detected on the primary interface) or the Bridge Control register Gf 
detected on the secondary interface). 


— For secondary bus address parity errors, the SErr Forward Enable bit 
is set in the Bridge Control register. 


4.10.2 Data Parity Errors on Initiator Bus 


If the 21052 detects a data parity error during a write transaction on the 
initiator bus, then the 21052: 
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Sets the detected Parity Error bit in the Status register that corresponds to 
the initiator bus. 


Asserts xperr_l if the Parity Error Response bit is set in the Command 
register (if the primary bus is the initiator bus) or the Bridge Control 
register (if the secondary bus is the initiator bus). 


Continues with the transaction. 


If a write transaction, forwards the bad parity condition with corresponding 
data to the target bus so that the target device is aware of the bad parity. 
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4.10.3 Data Parity Errors on Target Bus 


If the 21052 detects a data parity error during a read operation on the target 
bus, then the 21052: 


e Sets the Detected Parity Error bit in the Status register that corresponds 
to the target bus. 


e Asserts yperr_l if the Parity Error Response bit is set in the Command 
register (if the primary bus is the target bus) or the Bridge Control register 
(if the secondary bus is the target bus). 


e Sets the Data Parity Reported bit in the Status register that corresponds 
to the target bus if the Parity Error Response bit is set. 


e Returns the bad parity with the corresponding read data back to the 
initiator. 


e Continues with the transaction normally. 


If the 21052 detects yperr_l asserted during a write operation on the target 
bus, the 21052 sets the Data Parity Reported bit in the Status register that 
corresponds to the target bus if the Parity Error Response bit is set. 


If the transaction is a non-posted write and a data parity error is signaled, if 
possible, the 21052 asserts xperr_l on the initiator bus two cycles after write 
data is transferred from the initiator, if the Parity Error Response bit that 
corresponds to the initiator bus is set. If the timing of the transaction prevents 
assertion of xperr_l on the initiator bus, the 21052 asserts p_serr_l if: 


e The Parity Error Response bit corresponding to the target bus is set. 
e The p_serr_I Driver Enable bit is set. 
e The serr disable for posted write parity errors is not set. 


If the transaction is a posted write, then the 21052 asserts p_serr_I and set 
the Signaled System Error bit in the Primary Status register if: 


e The Parity Error Response bit corresponding to the target bus is set. 
e The p_serr_! Driver Enable bit is set. | 
e The serr disable for posted write parity errors is not set. 


In this case, the 21052 cannot pass back bad parity (because it is a write) or 
assert xperr_l during the proper cycle (because data is posted). 
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4.10.4 


Table 4—4 lists parity error signaling for transactions that are forwarded. 


Table 4—4 Data Parity Errors Signals for Forwarded Transactions 


Parity Error 


Transaction Detected on Initiator Bus Target Bus Primary Bus 
Posted write Target bus _ yperr_1° p_serr_]',° 
Initiator bus xperr_ |! yperr_1°, 4 = 
Non-posted write Target bus xperr_]',° yperr_1° p_serr_1’ 
Initiator bus xperr_ |! yperr_1°, 4 = 
Any read Target bus xperr |’, 4 yperr_|' = 
Initiator bus xperr |” ~— _ 


1Signal asserted by 21052. 

2Signal asserted by initiator. 

3Signal asserted by target. 

4Asserted because bad parity is passed with data across the 21052. 
Sserr disable for this event must be clear to assert p_serr_1 

Tf timing allows, otherwise assert p_serr_l. 


“If x_perr_l cannot be asserted. 


Other Errors 


The 21052 may be configured to assert p_serr_l for a variety of error 
conditions: 


e A yperr_l assertion on target bus is detected during posted write 
transaction. 


e Inability to deliver posted write data after 27+ attempts, as a result of 
target retry or disconnect. 


e A target abort is detected during a posted write transaction. 
e A master abort is received during a posted write transaction. 


Each condition has a corresponding disable bit in the serr disable register, 
that, when set, prevents p_serr_l from asserting when that condition occurs. 


The 21052 has a s_serr Forward Enable bit in the Bridge Control register 
which allows forwarding of s_serr_l to p_serr_l. The 21052 sets the Detected 
System Error bit in the secondary status register and the signaled system 
error bit in the primary status register. The 21052 does not assert s_serr_l. 
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The p_serr_1 Driver Enable bit must be set in the command register for the 
signal to be driven for any reason. If the 21052 drives p_serr_l, it also sets the 
Signaled System Error bit in the Primary Device Status register. 


When the p_serr_I signal is detected as asserted, the condition that caused the 
assertion may be decoded by checking the conditions listed in Table 4—5. 


Table 4—5 p_serr_! Assertion Conditions 


p_serr_! Assertion Condition 


s_serr_l| detected as asserted 


xperr_l detected on target bus 
during posted write 


Unable to deliver posted write 
data after 27* attempts 


Target abort detected during 
posted write 


No target response during posted 
write 


4.11 PCI Bus Arbitration 


This section describes the primary and secondary PCI bus arbitrations. 


4.11.1 


Asserted Status Bits 


Signaled System Error in primary status register 
and Detected System Error in secondary status 
register 


Signaled System Error in primary status register 
and Detected Parity Error in either primary or 
secondary status register 


Signaled System Error in primary status register 
and no other serr-related status bits asserted in 
the 21052 or in secondary bus devices 


Signaled System Error in primary status register 
and Received Target Abort in either primary or 
secondary status register 


Signaled System Error in primary status register 
and Received Master Abort in either primary or 
secondary status register 


Primary PCI Bus Arbitration 


The primary bus arbitration interface is a single request output and a grant 
input. The 21052 does not implement any centralized arbitration functions 
for the primary bus. The 21052 initiates transactions on the primary bus on 
behalf of initiators on the secondary bus. 


The 21052 asserts p_req_! when it needs to forward a transaction upstream. 
During the cycle immediately after the 21052 detects an asserted level on 
p_gnt_l and the primary bus is idle, the 21052 starts the transaction on the 


primary bus by 


— Asserting p_frame_l 


— Driving the address on p_ad<31:0> 
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— Driving the command on p_chbhe_l<3:0> 
— Deasserting p_req_l 


The 21052 may deassert p_req_l at any time before starting a transaction, for 
example, due to expiration of the target wait timer. 


The 21052 performs bus parking duties (driving p_ad, p_cbe_l, and p_par 
when the bus is idle) only when p_gnt_l is asserted and p_req_l is deasserted. 


4.11.2 Secondary PCI Bus Arbitration 


4.11.2.1 


The secondary bus central function pin, s_cfn_l, determines whether the 21052 
performs arbitration for access to the secondary PCI bus. If asserted low, the 
21052 performs arbitration. Otherwise, arbitration is assumed to be performed 
externally. 


The secondary PCI arbitration function can support up to four bus masters, in 
addition to the 21052. 


The 21052 includes itself in the arbitration for those transactions in which it 
is acting on behalf of an initiator on the primary bus. Because the primary 
and secondary buses operate concurrently, grants are given out independently 
of the status of the primary bus, and independently of the primary bus 
arbitration scheme. However, for all transactions that cross the 21052 except 
posted writes, both the primary and secondary buses must be acquired before 
data transfers on either bus can proceed. 


Secondary Bus Arbiter Protocol 


The arbiter re-assigns priorities every time s_frame_l is asserted (every time 
a new transaction starts). This starts a new arbitration cycle. From this point 
until the next transaction starts, the arbiter asserts the grant signal that 
corresponds to the highest priority request that is asserted.. 


If a grant for a particular request is asserted and a higher priority request 
subsequently asserts, then the arbiter deasserts the asserted grant signal and 
asserts the grant that corresponds to the new higher priority request on the 
next PCI clock cycle. , 


If the secondary PCI bus is busy (either s_frame_l or s_irdy_]l is asserted), 
then the arbiter may deassert one grant and assert another grant during the 
same PCI clock cycle. If the secondary PCI bus is idle, then the arbiter never 
asserts a grant signal in the same PCI cycle that it deasserts another. If it 
deasserts one grant, it asserts the next grant no earlier than one PCI clock 
cycle later. | 
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4.11.2.2 


4.11.2.4 


If the 21052 detects that an initiator has failed to assert s frame_l after 16 
cycles of both grant assertion and an idle bus condition, the arbiter deasserts 
the grant. That initiator does not receive any more grants until it deasserts its 
request for at least one PCI clock cycle. 


Priority Schemes 


The 21052 offers two priority schemes, which can be selected by using the 
Arbitration Mode Select bit in the Chip Control register. 


Alternating Mode 


The default priority scheme selected upon reset gives the 21052 highest priority 
on alternate arbitration cycles. This mode is selected when the Arbitration 
Mode Select is low. For cycles during which the 21052 does not have highest 
priority, the priority rotates evenly among the four external request inputs. 


Rotating Mode 


If the Arbitration Mode Select bit is set, a simple rotating priority scheme is 
used, in which highest priority rotates evenly between the five request inputs 
(four external requests and the 21052 request). 


Request Mask Timer 


The 21052 implements a programmable request mask timer. If the 21052 
issues a target retry in response to a secondary bus initiator, the request 


_ mask timer is started. That secondary bus initiator request is then masked 


for the number of PCI cycles programmed in the request mask timer which is 
contained in the Chip Control register in 21052 configuration space. When the 
timer expires, that initiator’s bus request may again be serviced. If a target 
retry is subsequently returned by the 21052 to another secondary bus initiator 
before expiration of the request mask timer, the latter’s bus request is masked 
only for the number of PCI cycles remaining in the timer. 


Secondary Bus Arbiter Disabled 


If s_cfn_l is tied high, it is assumed that secondary bus arbitration is 
performed externally to the 21052 and the secondary bus arbiter is disabled. 
The 21052 then reconfigures the following: 


e s_gnt_1<0> as secondary bus request output 
e s_req_1l<0> as secondary bus grant input 

e s_gnt_1l<3:1> outputs deasserted 

e s req_1<3:1> inputs ignored 


In this case, the 21052 secondary arbitration interface protocol is similar to 
the primary arbitration interface protocol. 
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4.11.2.5 Secondary Bus Parking 
If s_cfn_l is asserted low, the 21052 by default drives s_ad, s_cbe_l and s_par 
when the secondary bus is idle. If s_cfn_l is deasserted, the 21052 only drives 
these signals if s req_1<0>, configured as the 21052 external grant, is asserted. 
Note 


The s_cfn_! signal should be tied high or low through a resistive device 
since the input is connected to the diagnostic Nand tree and must be 
toggled during Nand tree testing. 


4.12 Clocks 


The 21052 has two clock inputs. The p_elk signal is referenced to the primary 
interface. All primary PCI bus signals are driven and sampled with p_clk. 
The s_clk signal is used by the secondary interface. All secondary PCI bus 
signals are driven and sampled with s_clk. 


e Both clocks operate at the same frequency and are synchronous to each 
other. 


e The maximum clock skew between p_clk and s_clk is no greater than 
7 nanoseconds. 


e The minimum clock skew between p_clk and s_clk is no less than 0 
nanoseconds. 


e The maximum operating frequency of the clocks is 33 Megahertz. 


Figure 4—21 shows the relative timing. 
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Figure 4-21 p_clk and s_clk Relative Timing 


s_clk 
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The 21052 provides five outputs, s_clk_o<4:0>, which can be used as secondary 
clock outputs. 


e One of these outputs can be fed back into the s_clk input of the 21052. 


e The other four clock outputs can be used as clock inputs for secondary bus 
devices. If these clock outputs are used for clock distribution, the s_clk 
input must still meet the timing requirements listed in Chapter 7. 


Here are suggested guidelines for using the secondary clock outputs: 


e When driving option slots, careful analysis of the primary and secondary 
clock skews should be done because the 21052 introduces a small amount 
of duty cycle skew into the secondary clock outputs. Refer to the DECchip 
21052 PCI-to-PCI Bridge Hardware Implementation: An Application Note. 


e Secondary clock delay external to the 21052 should not exceed 2 
nanoseconds. 


4.13 Reset 


4.13.1 


This section describes the primary, secondary, and chip reset bits. 


Primary Reset 


The 21052 has one reset input, p_rst_l. When asserted, p_rst_l causes 

the 21052 to immediately tristate all primary and secondary PCI interface 
signals. The 21052 resets all registers to 0 and clears all write buffers, unless 
designated otherwise (Chapter 5). The p_rst_l asserting and deasserting edges 
may be asynchronous to p_celk and s_clk. 
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4.13.2 


4.13.3 


Secondary Reset 


The 21052 is responsible for driving the secondary reset signal. There are 
three conditions during which s_rst_l can be asserted: 


e When p_rst_l is asserted. 


The s_rst_l signal remains asserted as long as p_rst_l is asserted. 


e When the Secondary Reset bit in the Diagnostic Control register is set. 


The s_rst_l signal remains asserted until the Secondary Reset bit is 
cleared by a configuration write. 


e When the Chip Reset bit in the Diagnostic Control register is set, s rst_l 
remains asserted until the Secondary Reset bit is cleared by a configuration 
write. 


When s_rst_l is asserted, s_ad, s_cbe, and s_par are immediately tristated 
and then driven low within a couple of clock cycles, while all other secondary 
interface signals are tristated. The 21052 still responds to accesses to its 
configuration space on the primary interface. Write buffers in both directions 
are cleared. 


Chip Reset 


The 21052 can be reset by setting the Chip Reset bit in the Diagnostic 
Control register. As soon as the chip reset is completed, the Chip Reset bit 

is automatically cleared within six PCI clock cycles and the chip is ready for 
configuration. While the chip is in reset, the 21052 is inaccessible for any type 
of transaction to or across it. | 
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Configuration Register Description 


This chapter provides programmer reference material for all 21052 
configuration space registers. Configuration space registers include the 
standard PCI device and PCI-to-PCI bridge registers, as well as other 
device-specific registers used during initialization. All registers located in 
configuration space are accessible only from the primary bus interface of the 
21052. Figure 5—1 shows a configuration space map. 


Preliminary—June 1995 5-1 


Figure 5-1 Configuration Space Map 











































































31 16 15 00 

Primary Interface Status Primary Interface Command 04h 

Primary Latency Cache Line Size 0Ch 

Timer 

Reserved 10h 

Reserved 14h 

Secondary Subordinate Bus Secondary Bus Primary Bus 18h 

Latency Timer Number Number Number 

Reserved 28h 

Reserved 2Ch 

Reserved 30h 

SErr Event Disable Burst Limit Counter Diagnostic Control Chip Control 40h 

pent Secondary Target Primary Target 44h 

Reserved Wait Timer Wait Timer 

m 
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5.1 Predefined Header Space Register Description 


This section provides a detailed description of predefined configuration space 
registers in the 21052. 


5.1.1 Device ID and Vendor ID Register 


This section describes the device ID and vendor ID register. 


31 16 15 00 
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Table 5-1 Device ID and Vendor ID Register 
Address 00 hex — 


Access <31:0> Read only. 
Field <31:16> Device ID identifies this device as the 21052 and is 
description internally hardwired to be 21h. 
<15:0> The Vendor ID identifies Digital Equipment Corporation as 
the vendor of this device and is internally hard wired to be 
1011h. 


5.1.2 Primary Status and Primary Command Register 


This section describes the primary status and primary command register. 


31 16 15 00 


04h 
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Table 5-2 Primary Status and Primary Command Register 


Address 04 hex — 

Access <31:27> Read/write-1-to-clear. 
<26:25> Read only. 
<24> Read/write-1-to-clear. 


(continued on next page) 
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Table 5—2 (Cont.) Primary Status and Primary Command Register 


Field 
Description 


<23> 
<22:9> 
<8:5> 
<4:3> 
<2:0> 
<31> 


<30> 
<29> 
<28> 
<27> 
<26:25> 


<24> 


<23> 


<22:10> 


<9> 


<8> 


<7> 


<6> 
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Read only. 

Read only as 0. 

Read/write. 

Read only. | | 
Read/write. 


Detected Parity Error on primary bus. 


Signaled System Error on primary bus. 
Received Master Abort on primary bus. 
Received Target Abort on primary bus. 
Signaled Target Abort on primary bus. 


p_devsel_1 timing for the 21052 acting as target on 
primary bus. Set to 01b to designate medium timing. 


Data Parity Detected. Set when the 21052 is acting as 

a master on the primary bus, p_perr_l is detected as 
asserted, or a parity error is detected on the primary bus, 
and the Parity Error Response bit in the primary command 
register is set. 


Fast back-to-back capable. Reads only as a 1 to 
indicate that the 21052 can respond to fast back-to-back 
transactions on the primary bus. 


Reserved. Reads only as 0. 


Fast back-to-back control. Reads only as 0 to indicate that 
the 21052 will not perform fast back-to-back accesses to 
targets on the primary bus. 


p_serr_l driver enable. If high, the 21052 can drive 
p_serr_l. If low, the p_serr_! driver is disabled. Reset to 
0. 


Wait Cycle Control. Reads only as 0 to indicate that the 
21052 does not do address stepping, with the exception of 
downstream Type 1 to Type 0 configuration transactions. 


Parity error response. When this bit is low, parity checking 
is disabled on the primary bus interface. Reset to 0. 
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Table 5-2 (Cont.) Primary Status and Primary Command Register 


<5> VGA Snoop Enable. If set, enables VGA snooping for the 
21052. The 21052 positively decodes VGA palette register 
I/O writes and ignores palette register I/O reads. 


<4:3> Reserved. Will read as 0. 


<2> Master enable. When set high, 21052 can act as a master 
on the primary bus. Reset to 0. 


<1> Memory transaction target enable. When set high, the 
21052 can respond as a target to memory transactions on 
the primary bus. Reset to 0. 


<0> I/O Transaction target enable. When set high, the 21052 
can respond as a target to I/O transactions on the primary 
bus. Reset to 0. 


5.1.3 Class Code/Programming Interface/Revision ID Register 


This section describes the class code/programming interface/revision ID 
register. 


31 24 23 16 15 08 07 00 


08h Base Class Code Sub-Class Code Prog. Interface 


LJ-03242-T10 


Table 5-3 Class Code/Programming Interface/Revision ID Register 


Address 08 hex ~~ 

Access <31:0> Read only. 

Field <31:24> Base class code of the device. Reads as 06h to indicate that 
description it is a 21052 device. 


<23:16> Sub-class code of the device. Reads as 04 hex to indicate 
that device is a 21052. 


<15:8> Programming interface of the device. Reads as all 0’s. 
<7:0> Revision ID for the 21052. 
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5.1.4 Primary Master Latency Timer/Cache Line Size/Header Type 


This section describes the primary master latency timer (MLT)/cache line 


size/header type register. 


0Ch 





31 24 23 16 15 08 07 00 
| Reserved | Header Type Primary MLT | Cache Line Size 
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Table 5-4 Primary Master Latency Timer/Cache Line Size/Header Type 


Address 


Access 


Field 
Description 


Register 


OC hex 
<31:24> 
<23:16> 
<15:11> 
<10:8> 
<7:0> 
<31:24> 


<23:16> 


<15:8> 


<7:0> 
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Reads only as 0’s. 
Read only. 
Read/write. 

Read only as 0’s. 
Read/write. 


Reserved. Reads as all 0’s. 


Header type. Defines the layout of addresses 10 hex 
through 3F hex in configuration space. Reads only as 01 
hex to indicate that the register layout conforms to the 
PCI-PCI bridge layout. 


Master latency timer for primary interface. Designates the 
maximum number of PCI clock cycles from the assertion of 
p_frame_I until the expiration of the timer. The lower 3 
bits are read only, giving a granularity of eight PCI clock 
cycles. If 0, the timer is not used. Reset to 0. 


Cache line size. Designates the cache line size for the 
system in units of 32-bit words. The cache line size is 
restricted to be a power of 2. The most significant 1 in the 
cache line size register is used to set the cache line size. 
Any other 1’s are ignored. Used when terminating memory 
write and invalidate transactions and when prefetching 
during memory read type transactions. Reset to 0. 


5.1.5 Reserved Registers (10—14 Hex) 


This section describes the reserved registers (10—14 hex). 


31 
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Table 5-5 Reserved Registers (10—14 Hex) 


Address 10—14 — 
hex 
Access — Reads only as 0’s. 
Field _ All registers are reserved and read as 0’s. 
description 


5.1.6 Primary Bus Number/Secondary Bus Number/Subordinate Bus 
Number/Secondary Master Latency Timer Register 


This section describes the primary bus number/secondary bus number 
/subordinate bus number/secondary master latency timer register. 


31 24 23 16 15 08 07 00 


LJ-03245-TI0 
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Table 5-6 Primary Bus Number/Secondary Bus Number/ Subordinate Bus 
Number/Secondary Master Latency Timer 


Address 18 hex 
Access <31:27> 
<26:24> 
<23:0> 
Field <31:24> 
description 
<23:16> 
<15:8> 
<7:0> 
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Read/write. 
Read only as 0. 
Read/write. 


Master Latency Timer for secondary interface. Designates 
the maximum number of PCI clock cycles from the 
assertion of s_frame_l until the expiration of the timer. 
The lower 3 bits are read only, giving a granularity of eight 
PCI clock cycles. If 0, the timer is not used. Reset to 0. 


The subordinate bus number. Defines the inclusive upper 
limit of a range of bus numbers. This range determines 
whether configuration accesses are to be forwarded across 
the 21052 to the secondary bus. Reset to 0. 


The secondary bus number. Enables accesses to 
configuration space of a hierarchical PCI bus. If matched 
to a number driven during the Type 1 address cycle on the 
primary bus, the access is for a device on the secondary 
bus. Also provides the non-inclusive lower limit for the bus 
number range described above. Reset to 0. 


Primary bus number. Designates the primary bus. Used 
to decode Type 1 configuration cycles initiated on the 
secondary bus intended for special cycle generation on the 
primary bus. Reset to 0. 


5.1.7 I/O Base Address/i/O Limit Address/Secondary Status Register 


This section describes the I/O base address/I/O limit address/secondary status 
register. 


31 


16 15 08 07 00 


1Ch Secondary Status I/O Lim. Address 1/O Base Address 
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Table 5-7 I/O Base Address/I/O Limit Address/Secondary Status Registers 


Address 1C hex — 
Access <31:27> Read/write-1-to-clear. 
<26:25> Read only. 
<24> Read/write-1-to-clear. 
<23> Read only. 
<22:16> Read only as 0. 
<15:12> Read/write. 
<11:8> Read only as 0. 
<7:4> Read/write. 
<3:0> Read only as 0. 
Field <31> Detected Parity Error on secondary bus. 
description 
<30> Detected System Error on secondary bus — s_serr_l 
detected asserted. 
<29> Received Master Abort on secondary bus. 
<28> Received Target Abort on secondary bus. 
<27> Signaled Target Abort on secondary bus. 
<26:25> — s_devsel_l timing for the 21052 acting as target on 
secondary bus. Set to 01b to designate medium timing. 
<24> Data Parity Detected. Set when the 21052 is acting as a 


master on the secondary bus, and s_perr_]l is detected as 
asserted, or a parity error is detected on secondary bus, 
and the Secondary Parity Response bit is set in the 21052 
control register. 


(continued on next page) 
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Table 5-7 (Cont.) I/O Base Address/I/O Limit Address/Secondary Status 
| Registers 


<23> 


<22:16> 
<15:12> 


<11:8> 
<7:4> 


<3:0> 
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Fast back-to-back capable. Reads only as 1 to indicate that 
the 21052 can respond to fast back-to-back transactions on 
the secondary bus. 


Reserved. 


Contains bits <15:12> of the I/O limit address, or upper 
limit (inclusive), which defines an address range used to 
determine whether to forward I/O transactions from the 
primary to the secondary bus. The 16 most significant 
bits of the address are assumed to be 0. The 12 least 
significant bits of the address are assumed to be FFF hex. 
Reset to 0. 


Reserved. Reads as 0. 


Contains bits <15:8> of the I/O base address, or lower 
address limit, which defines an address range used to 
determine whether to forward I/O transactions from one 
PCI bus to the other. Both the 16 most significant address 
bits and 8 least significant address bits are assumed to be 
0. This register is reset to 0. 


Reserved. Reads as 0. 


5.1.8 Memory Base Address/Memory Limit Address Register 


This section describes the memory base address/memory limit address register. 


31 


16 15 00 


20h | Memory Limit Address Memory Base Address 
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Table 5-8 Memory Base Address/Memory Limit Address Register 


Address 20 hex 

Access <31:20> 
<19:16> 
<15:4> 
<3:0> 


Field <31:20> 
description 


<19:16> 
<15:4> 


<3:0> 


Read/write. 
Read only as 0. 
Read/write. 
Read only as 0. 


Defines the most significant 12 bits of the upper 

limit Gnclusive) of the memory address range. The 
minimum memory address range is 1 megabyte. The 

20 least significant bits of the memory limit address should 
be assumed to be FFFFFh. For memory read transactions, 
the 21052 does not prefetch data in this address range, and 
memory read transactions are limited to one data burst. 
Reset to 0. 


Reserved. Reads as 0. 


Indicates the upper 12 bits of the base address, or lower 
address limit, of a memory address range. This range is 
used to determine whether to forward memory accesses 
across the 21052. The minimum memory address range is 
1 megabyte. The 20 least significant bits of the memory 
base address should be assumed to be 00000h. For memory 
read transactions, the 21052 does not prefetch data in this 
address range, and memory read transactions are limited 
to one data burst. Reset to 0. 


Reserved. Reads:as 0. 
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5.1.9 Prefetchable Memory Base Address/Prefetchable Memory Limit 


Address Register 


This section describes the prefetchable memory base address/prefetchable 
memory limit address register. 


31 


16 15 00 


24h Prefetchable Memory Limit Address Prefetchable Memory Base Address 
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Table 5-9 Prefetchable Memory Base Address/Prefetchable Memory Limit 
Address Register 


Address 24 hex 

Access <31:20> 
<19:16> 
<15:4> 
<3:0> 


Field <31:20> 
description 


<19:16> 
<15:4> 


<3:0> 


Read/write. 
Read only as 0. 
Read/write. 
Read only as 0. 


Defines the most significant 12 bits of the upper 

limit Ginclusive) of the memory address range. The 
minimum memory address range is 1 megabyte. The 

20 least significant bits of the memory limit address should 
be assumed to be FFFFFh. The 21052 prefetches data in 
this address range. Reset to 0. 


Reserved. Reads as 0. 


Indicates the upper 12 bits of the base address, or lower 
address limit, of a memory address range. This range is 
used to determine whether to forward memory accesses 
across the 21052. The minimum memory address range is 
1 megabyte. The 20 least significant bits of the memory 
base address should be assumed to be 00000h. The 21052 
prefetches data in this address range. This register is reset 
to 0. 


Reserved. Reads as 0. 


5.1.10 Reserved Registers (28—38 Hex) 


This section describes the reserved registers (28—38 hex). 
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31 00 


28h Reserved 


38h Reserved 
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Table 5-10 Reserved Registers (28—38 Hex) 


Address 28h—38h — 

Access _ Read only as 0. 

Field — These registers are reserved and read only as 0’s. 
description 


5.1.11. Interrupt Pin/Bridge Control Register 


This section describes the interrupt pin/bridge control register. 


31 16 15 08 07 00 
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Table 5—11 
Address 


Access 


Field 
description 


Interrupt Pin/Bridge Controi Register 


3Ch 
<31:24> 
<23:21> 
<20> 
<19:16> 
<15:0> 
<31:26> 


<23> 


<22> 


| <21> 


<20> 
<19> 


<18> 
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Reserved. 
Read/write. 
Read only as 0. 
Read/write. 
Read only. 


Reserved. Read only as 0. 


Fast back-to-back control. Reads only as zero to indicate 
that the 21052 will not perform fast back-to-back accesses 
to targets on the secondary bus. 


Secondary Bus Reset. When set high, the 21052 tristates 
secondary bus outputs and immediately terminates any 
transactions involving the secondary interface. The s_rst_l 
signal is asserted until this bit is cleared by a configuration 
write. The primary bus interface is still active and the 
21052 responds to accesses to its internal configuration 
state. The configuration state is not cleared. All write 
buffers will be cleared. 


Master Abort mode. When set, the 21052 signals a target 
abort to the initiator when a master abort is detected 

for reads and non-posted writes. If 0, reads return 
FFFFFFFFh, and write data is transferred to the 21052 
and discarded. Reset to 0. | 


Reserved. Read only as 0. 


VGA Enable. When set, allows the 21052 to forward 
transactions downstream directed at a VGA device (to 
memory addresses A0000h through BFFFFh and to I/O 
addresses 03BOh through 03DFh except 3BCh-3BFh). 
These addresses are independent of the memory and 
I/O ranges described by the memory base and address 
registers. Reset to 0. 


ISA Enable for I/O transactions. When set, makes the 
21052 ISA-aware. When set, the 21052 blocks any 
forwarding of transactions addressing the last 768 bytes in 
each 1 Kbyte chunk of I/O address space. Applicable to I/O 
space within the J/O base and limit address registers only. 
Reset to 0. 


(continued on next page) 


Table 5-11 (Cont.) Interrupt Pin/Bridge Control Register 


<17> s_serr_l forward enable. If high, allows forwarding of 
s_serr_] on secondary address parity errors to the primary 
bus via assertion of p_serr_l. Reset to 0. 


<16> Parity Error Response. When low, disables parity checking 
on the secondary bus interface. Reset to 0. 


<15:8> Interrupt pin. Designates which interrupt signal the 
device uses. Reads only as a 00h, because the 21052 does 
not generate an interrupt. 


<7:0> Reserved. Read only as 0. 


5.2 Implementation-Specific 21052 Register Descriptions 


This section offers a detailed description of implementation-specific 
configuration registers. 


5.2.1 Chip Control/Diagnostic Control/Burst Limit Counter/serr Disable 
Register 


This section describes the chip control/diagnostic control/burst limit counter 
/serr disable register. 


31 16 15 00 


40h SErr Disable Burst Counter Diag. Control Chip Control 
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Table 5-12 Chip Control/Diagnostic Control/Burst Limit Counter/serr Disable 


Register 
Address 40h 


Access _ <31:0> 


Field <31:24> 
description 


<23:16> 


<15:13> 


<12> 


<11> 


<10> 


<9> 
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Read/write. 


serr disable. When set, the following bits prevent 
p_perr_l from being asserted for the following conditions: 


Bits Description 


<31:29> Reserved 


<28> Master abort on posted write 

<27> Target abort during posted write 

<26> Unable to deliver posted write data 

<25> Bad data parity on target bus for posted write 
<24> Reserved 


Burst Limit Counter. Specifies the maximum number of 
data transfers that can occur during any transaction. The 
top 2 bits are hard-wired to be 0, leaving a maximum burst 
range from 1 to 64 data transfers. If 0, no burst limits are 
applied. Reset to 0. 


Reserved. Read only as 0. 


p_serr_I diagnostic mode assertion control. When set to 

1, the 21052 asserts the p_serr_l signal in response to all 
address phases on the primary PCI bus. This bit should be 
used for diagnostic purposes only. Reset to 0. 


s_perr_l diagnostic mode assertion control. When set to 
1, the 21052 asserts the s_perr_| signai in response to all 
write data phases on the secondary bus intended for the 
21052 or a primary bus device. This bit should be used for 
diagnostic purposes only. Reset to 0. 


p_perr_l diagnostic mode assertion control. When set to 
1, the 21052 asserts the p_perr_l signal in response to 
all write data phases on the primary bus intended for the 
21052 or a secondary bus device. This bit should be used 
for diagnostic purposes only. Reset to 0. 


Test mode. Used for chip test. When set to 1, all counters 
greater than 4 bits will be sub-divided into parallel 4 bit 
chunks by forced carry signals. Reset to 0. 


(continued on next page) 


Table 5-12 (Cont.) Chip Control/Diagnostic Control/Burst Limit Counter/serr 


<8> 


<7:5> 


<4> 


<3:2> 


<l> 


<Q> 


Disable Register 


Chip Reset. When set, the 21052 performs a chip reset. 
All configuration registers are returned to their reset state 
and the 21052 must be reconfigured. This bit is cleared by 
the chip upon completion of reset. s_rst_l is asserted until 
the secondary reset bit is cleared. 


Reserved. Reads as 0. 


Secondary bus prefetch disable. If not set, memory 

read transactions initiated on the secondary bus use 
prefetching. If set, memory read transactions are 
disconnected after one data transfer. Memory read 

lines and memory read multiple transactions always 

use prefetching and may consist of multiple data transfers. 
Reset to 0. 


Request mask timer. Designates the maximum value of 
the request mask timer, which is enabled after the 21052 
issues a target retry to a master on the secondary bus. 
Reset to 0. 


00b—mask timer not used 
01b—16 PCI clock cycles 
10b—32 PCI clock cycles 
11b—64 PCI clock cycles 


Disable Posting Enable. If set, posting is disabled for 
all memory write, and memory write and invalidate 
transactions. Reset to 0. 


Secondary PCI bus arbitration mode select. When set, 
selects rotating priority between all secondary bus 
requests. If not set, arbitration is also rotating priority, 
except that the 21052 has highest priority on alternate 
arbitration cycles. Reset to 0. 


5.2.2 Primary Target Wait Timer/Secondary Target Wait Timer Register 


This section describes the primary target wait timer/secondary target wait 


timer register. 
31 


44h 





16 15 08 07 00 
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Table 5-13 Primary Target Wait Timer/Secondary Target Wait Timer Register 


Address 44h 
Access <31:16> 
<15:0> 
Field <31:16> 
descriptions 
<15:8> 
<7:0> 
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Read only as 0’s. 
Read/write. 


Reserved. Read only as 0’s. 


Secondary interface target wait timer. A programmable 
register which indicates the maximum number of PCI 
cycles that the 21052 waits to gain access to the target 
(primary) bus for a transaction initiated on the secondary 
bus. If the timer expires before the 21052 receives a grant 
for the primary bus, the 21052 issues a target retry to the 
initiator on the secondary bus and deasserts its primary 
bus request. If 0, the 21052 waits indefinitely. Reset to 0. 


Primary interface target wait timer. A programmable 
register which indicates the maximum number of PCI 


cycles that the 21052 waits to gain access to the target 


(secondary) bus for a transaction initiated on the primary 
bus. If the timer expires before the 21052 receives a 
grant for the secondary bus, the 21052 issues a target 
retry to the initiator on the primary bus and deasserts its 
secondary bus request. If 0, the 21052 waits indefinitely. 
Reset to 0. 


5.2.3 Secondary Write Attempt Counter Register 


This section describes the secondary write attempt counter register. 


31 00 


48h Secondary Write Attempt Counter 
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Table 5-14 Secondary Write Attempt Counter Register 


Address 48h ~ 

Access — Read only 

Field _ A read-only register which shows the number of attempts 
description that have been made to empty data in the downstream 


write buffer. Used for diagnostic purposes. Reset to 0. 


5.2.4 Primary Write Attempt Counter Register 


This section describes the primary write attempt counter register. 


31 00 
4Ch | Primary Write Attempt Counter | 
LJ-03431-TI0 


Table 5-15 Primary Write Attempt Counter Register 


Address 4Ch — 

Access — Read only 

Field ~ A read-only register which shows the number of attempts 
description that have been made to empty data in the upstream write 


buffer. Used for diagnostic purposes. Reset to 0. 
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5.2.5 Reserved Registers (50h—FFh) 


5-20 


This section describes the reserved registers (560h—FFh). 


FFh Reserved 
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Table 5-16 Reserved Registers (50h - FFh) 


Address 50h-FFh —- 

Access — Read only as 0. 

Field — Reserved and read only as 0’s. 
description 
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Diagnostics and Test Mechanisms 


This chapter provides testing and diagnostics information. 


6.1 Test Pins and Nand Tree Implementation 
The 21052 implements two pins for testing purposes. 
e The goz_l pin, when asserted, tristates all bidirectional pins. 


e The nand_out pin is the output of a serial Nand tree connecting all chip 
inputs, except p_clk and s_clk. A pattern can be applied to chip inputs, 
and the nand_out pin verifies input pin interconnect. 


When using the Nand tree test mechanism, all bidirectional signals must first 
be tristated by assertion of goz_l. The goz_l signal should remain asserted for 
the duration of this test. 

Note 


Any inputs tied high or low, s_cfn_l for example, should be connected 
to power or ground through a resistive device to allow use of the Nand 
tree feature. 


The Nand tree begins at the s_cfn_] input and runs clockwise to p_rst_l, and 
then is output at nand_out. 


The suggested Nand tree test sequence is: 
1. Drive goz_]l low. 


2. Drive each input and bidirectional pin high, with the possible exception of 
p_clk and s_clk. (p_clk and s_clk are not included in the Nand tree). 


3. Starting with pin 49 (s_cfn_]), individually drive each pin low; nand_out 
should toggle with each pin. Proceed clockwise, driving each subsequent 
pin low. 


4, Turn off tester drivers. 
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5. Drive goz_l high. 
6. Reset chip before proceeding with further testing. 


6.2 Diagnostic Control Register 


The 21052 implements three bits for xperr_l and p_serr_l control in the 
Diagnostic Control register, which exists in 21052 configuration space. 


Caution 


These bits should never be set during normal chip operation or 
initialization. 


When the xperr_| control bit is set, the 21052 returns xperr_l to the master 
of any write transaction occurring on that bus. The 21052 asserts p_perr_l in 
response to all write transaction data phases initiated on the primary bus and 
directed to or across the 21052 when the p_perr_l control bit is set. Similarly, 
when the s_perr_l control bit is set, the 21052 asserts s_perr_l in response to 
all write transaction data phases initiated on the secondary bus and directed 
across the 21052 chip. | 


When the p_serr_I control bit is set, the 21052 returns p_serr_l to the master 
in response to any address phase occurring on the primary bus. The 21052 
continues to respond to transactions, unless a real address parity error is 
detected. 


The 21052 also implements a test mode bit in the Diagnostic Control register 
to facilitate chip fault test. When set, all counters in excess of 8 bits are 
broken up into 4-bit chunks by a forced carry signal. The 4-bit chunks of any 
particular counter will count in parallel when the chip is in test mode. The 
test mode bit should not be set unless all 21052 state machines are idle, that 
is, there are no transactions in progress across the 21052 chip. 
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DECchip 21052 Specifications 


This chapter describes the mechanical and electrical specifications of the 


21052. 


7.1 Mechanical Specifications 


The following sections describe the mechanical specifications of the 21052. 


7.1.1 DECchip 21052 Package 


The DECchip 21052 PCI chip is packaged in a 160-pin PQFP. Table 7-1 lists 
the mechanical specifications, and Figure 7-1 shows the package dimensions of 


the DECchip 21052. 


Table 7—1 Lead Counts and Dimensional Attributes 


Symbol Limit 
LL REF 
e BSC 
L MIN 
L MAX 
A MAX 
Al MIN 
A2 MIN 
A2 MAX 
b MIN 
b MAX 
c MIN 


Dimensions in Millimeters 


1.6 
0.65 
0.65 
1.03 
4.5 
0.25 
3.17 
3.67 | 
0.22 
0.38 
0.12 


(continued on next page) 
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Table 7-1 (Cont.) Lead Counts and Dimensional Attributes 


Symbol Limit Dimensions in Millimeters 
c MAX 0.23 
ccc — 0.1 
ddd — 0.13 
ttt — 0.25 
D BSC 31.2 
D1 BSC 28 
E BSC 31.2 
E11 BSC 28 
R MIN 0.13 
R MAX 0.3 
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Figure 7-1 Package Dimensions 
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7.1.2 Absolute Maximum Ratings 


This section lists the absolute maximum ratings. 


Vop 
Ty 
Ts 


Pwe 


3.0 V-3.6 V 
100°C 

70°C 

0.85 W 

—55°C to 125°C 


Storage temperature 


7.2 Electrical Specifications 


The following sections describe the electrical specifications of the 21052. 


7.2.1 Interface Signal DC Electrical Specifications 


Table 7—2 defines the dc parameters met by all 21052 signals. 


Table 7-2 DC Specifications 


Symbol Parameter Condition Minimum Maximum Units 
V; Input high voltage — A75 Vpp 5.5V V 
V; Input low voltage - —0.5 3825 Vop V 
Tin Input high leakage V,, = 2.7 V ~ 70 pA 
current’ 
FF Input low leakage 0<V;2n<Vopb — +10 pA 
current? 
Von” Output high Tour = —500 9VpbD _ V 
voltage 
Vonsv Output high Iour = —2mMA 2.4 — V 
voltage 
Vor" Output low voltage Iu; = 1500 — 1Vpp V 
pA 
Vov? ,* Output low voltage Tout = 6 mA R}5) — V 
| or 
Lous = 3 mA - 
Cin Input pin — — 10 pF 
| capacitance | 


(continued on next page) 
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Table 7-2 (Cont.) DC Specifications 


Symbol Parameter Condition Minimum Maximum Units 

Cy DSEL p_idsel pin = a 8 pF 
capacitance 

Celk p_clk, s_clk pin ae 5 12 pF 
capacitance 

Footnotes: 


1. Input high leakage current and input low leakage current include J,,) or 


I,,, leakage current for bidirectional signals. 
2. For 3.3-volt signaling environment. 


For 5.5-volt signaling environment. 


4. Most output low voltage signals have 3 mA of current. The following 


output low voltage signals have 6 mA of low output current: 


p_frame_l p_trdy_l p_irdy_l 
p_stop_l p_serr_l p_perr_l 
s frame_l s_trdy_l s irdy 

s_stop_l s_perr_] s_lock_l 


7.2.2 Interface Signal AC Timing Specifications 
Table 7—3 and Figure 7—2 show the p_clk and s_clk ac timing. 


Table 7-3 p_clik and s_clk AC Timing 


Symbol Parameter Minimum Maximum Units 
Tae xelk cycle time 30 — ns 
Thigh xelk high time 12 ns 
Tiss xcelk low time 12 — ns 

Slew rate 1 V/ns 
df pes Delay from p_elk to 0 ns 


s clk 


p_devsel_] 
p_lock_l 


s devsel I 


Notes 


@1.5 V and 
@1 V/ns 


@1.5 V and 
@1 V/ns 


0.4 to 2.4 V 
@15V 


(continued on next page) 
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Table 7-3 (Cont.) p_clk and s_clk AC Timing 


Symbol Parameter Minimum Maximum Units Notes 

Tsclkr p_clk rising to s_clk_ 0 5 ns @1.5 V' 
o<4:0> rising 

Toctkf p_clk falling to s_clk_ 0 D ns @1.5 V! 


0<4:0> falling 


1Measured with 30 pF lumped load. 


Figure 7-2 p_clik and s_clk AC Timing 
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7.2.3 Input Signal AC Timing Specifications 


Table 7-4 and Figure 7—3 show the input signal ac timings, and Table 7—5 
shows the timing specifications for xrst_l. 


Table 7—4 Input Signal AC Timings 


Symbol Parameter Minimum Maximum Units 

Ta xclk-to-xsignal valid delay— 2 11 ns — 
bused signals’, ”, ° 

Tvat (ptp) xelk-to-xsignal valid delay— 2 12 ns 
point-to-point *, 7, ° 

fee Float-to-active delay ' 2 = ns 

Toff Active-to-float delay * — 28 ns 

Tis Input setup time to xclk— bused 7 — ns 
signals’, ° 

Tou (ptp) Input setup time to xelk— 10, 12 = ns 
point-to-point’, ° 

Th Input signal hold time from 0 — ns 
xelk' 


1All primary interface signals are used by p_celk and all secondary interface signals are used by 
s_clk. 


2Minimum times measured with 0-pF equivalent load. Maximum times measured with 50-pF 
equivalent load. 

3Point-to-point signals are p_req_l, s_req_1<3:0>, p_gnt_l, s_gnt_1<3:0>, and s_cfn_l. 

All other PCI signals are shared. 

All xgnt_l signals and s_cfn_l have a setup time of 10 ns. 

xreq_l has a setup time of 12 ns. 


Preliminary—June 1995 7-7 





Figure 7-3 AC Timing Waveforms 
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Table 7-5 xrst_l Timing Specifications 


Symbol 
fe at 


dT preiaelk 
Ppret—of f 
Tort 
Teret—on 


Tsrst—of f 


Parameter 


p_rst_l active time after power 
stable 


p_rst_l active time after p_clk 
stable 


p_rst_l active to output float 
delay 


s_rst_l active after p_rst_l 
assertion 


s_ rst_l active time after s_clk 
stable 


s_rst_l active to secondary 
output float delay 
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Minimum Maximum Units 


1 


100 


40 


40 


40 


ps 
ps 
ns 
ns 
ps 


ns 


A 


Technical Support, Ordering, and 
Associated Literature 


This appendix describes how to obtain information and technical support, as 
well as how to order Digital’s products and associated literature. 


A.1 Digital Semiconductor Information Line 


If you need technical support or help deciding which literature best meets your 
needs, call the Digital Semiconductor Information Line: 


United States and Canada 1-800-332-2717 
TTY (United States only) 1-800-332-2515 
Outside North America +1-508-568-6868 


A.2 Ordering Digital Semiconductor Products 


To order the following Digital Semiconductor products, contact your local 
Digital sales office or local distributor. 


Product Order Number 


DECchip 21052 PCI-to-PCI Bridge 21052-—AA 
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A.3 Ordering Associated Literature 


The following table lists the DECchip 21052 literature that is available. For 
ordering information, contact the Digital Semiconductor Information Line. 


Title Order Number 
DECchip 21052 PCI-to-PCI Bridge Product Brief EC—QHUQA-TE 
DECchip 21052 PCI-to-PCI Bridge Evaluation Board EC-—QKHJA-TE 
User’s Guide 

DECchip 21052 PCI-to-PCI Bridge Configuration: EC-—QLZBA-TE 
An Application Note 

DECchip 21052 PCI-to-PCI Bridge Hardware EC-—QLZAA-TE 


Implementation: An Application Note 


A.4 Ordering Third-Party Literature 


You can order the following third-party literature directly from the vendor. 


Title Vendor 
PCI Local Bus Specification, PCI Special Interest Group 
Revision 2.0 M/S HF3-15A 


5200 N.E. Elam Young Pkwy 
Hillsboro, Oregon 97124—6497 
(503) 696-2000 
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